【お題】引っかけ問題(締め切り10月27日(日)23時)

タイトルの通りですが、ちょっと検索した限りだと
ひっかかってきませんでした。できない
という見解は正しいでしょうか?
よろしくお願いします。

A 回答 (6件)

○VBAのワークシート関数がどのようなロジックやアルゴリズムで処理しているか、通常人には判らない。

公表されていない。
○また同じことを平易なロジックやアルゴリズムでやれるという保証も無いし、相当プログラムの経験とロジックを使いなれないと作ることもできないかもしれない。(聞いている人の能力と関係する。)
○ワークシート関数は、自動反映を期して、シートの1箇所変わると、全部の式が関係あるかチェックし、計算するようです。
#5で紹介されいることぐらいは手を打つとして、できるものはバッチ処理方式を取り入れた計算や処理にすると良い場合がありそう。ソートなどを多用する、昔の方式ですが、処理に無駄が無い場合が多い。
○結局このような質問は、個別の問題であるので、質問者も回答に十分満足がなされないでしょう。自分で経験して会得するより無いでしょう。
多数の関数を使っている場合もあり、OKWAVEに質問も出しにくいでしょう。
>Excel関数をVBAの関数に変換できますか
#1の補足を見ても、表題は質問者の関心事を捕らえていないのでは。
文章どおり採ると、プログラム力が有ればできる、となってしまう。
機械的にセルのFormulaをWorkSheetFunctionをつけて実行できるかというと、VBAのワークシート関数の一覧か関数事典でVBAの表示の有無があるものがあり、参考になるでしょう。しかし自動変換というわけには行かないでしょう。
    • good
    • 0

#02です。


VBAでワークシート関数を使用して処理時間がかかるようになったのなら、以下を試してみてください

VBA実行の最初に
Application.ScreenUpdating = False  '画面描画の停止
Application.Calculation = xlManual  '関数自動計算の停止

VBA終了時に
Application.ScreenUpdating = True  '画面再描画の再開
Application.Calculation = xlAutomatic  '関数再計算

効果があると思います
    • good
    • 0
この回答へのお礼

ありがとうございます。
一応描画の対策は打っていて、少しましに
なりました;

お礼日時:2006/05/31 22:56

#1補>Excel関数が複雑すぎたためにパフォーマンスの劣化がおきてしまい…


エクセルのワークシートの関数で処理しているときに、
それぞれのセルは独立したプログラムみたいなものなので、
同じ範囲の演算を繰り返ししている場合があります。
そのような場合に、演算を1つにし結果を各セルに書き出すようにすれば、パフォーマンスを良くする可能性があると思います。
    • good
    • 0
この回答へのお礼

ひとつのセルにIFやらCOUNTやらを
大量に使ってあるのですが、その様な
セルがさらに大量にあります;
いざプログラムに落とそうとしたら
すごく大変になってしまったという経緯が
あります;
少しずつ分離して試して見ます。
ありがとうございます。

お礼日時:2006/05/31 22:59

質問の意味が良くわからないのですが…



Application.WorksheetFunction.関数 (引数)

で、ワークシートの関数を使えます。
ただし、そのままと言うわけにはいかず、範囲指定はVBAの書き方になってきます。

x = Application.WorksheetFunction.Sum(Range("A1:A10"))
    • good
    • 0
この回答へのお礼

回答ありがとうございます。
補足を最下にさせていただきました。

お礼日時:2006/05/31 18:49

ワークシート関数をVBAで使えるか? という質問でしょうか。



Applicationを頭につけて、こんな感じで使います

Sdate = Application.Fixed(Range("AB1"), 0, True)

Kekka = Application.Match(Cells(Gyo, 4), Worksheets("sheet1").Range("F1:F20"), 0)
    • good
    • 0
この回答へのお礼

回答ありがとうございます。
補足を最下にさせていただきました。

お礼日時:2006/05/31 18:49

違っているかもしれませんが、仰りたいのは「ワークシート関数をVBAで使いたい」って事ですか?


それなら下記のサイトを参考にしてください。

参考URL:http://www.moug.net/tech/exvba/0100035.htm

この回答への補足

回答ありがとうございます。
参考にさせていただきました。
ただ、説明が不足していて申し訳ありませんが、
例えばSUM(A1、A2)がExcel関数であるとしたら
VBAで、for文の様な形で和を出すような(このレベル
になるとツールになるかもしれません;方法が一つ
ではないと思うので)ことはできるかどうかという
ことです。
目的としては、Excel関数が複雑すぎたために
パフォーマンスの劣化がおきてしまい、VBAで
計算した後にSheetに入れようと思いました。
処理速度的にはどこかのサイトで速くなる意味合い
のことをみました。(関数のVolumeにもよると思い
ますが)
回答してくださった方々のような、VBAでExcelの
関数を呼ぶ場合は速度的にはどのような感じに
なるでしょうか?
よろしくお願いします。

補足日時:2006/05/31 18:40
    • good
    • 0

お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!

このQ&Aを見た人はこんなQ&Aも見ています


おすすめ情報