![](http://oshiete.xgoo.jp/images/v2/pc/qa/question_title.png?a65a0e2)
No.6ベストアンサー
- 回答日時:
○VBAのワークシート関数がどのようなロジックやアルゴリズムで処理しているか、通常人には判らない。
公表されていない。○また同じことを平易なロジックやアルゴリズムでやれるという保証も無いし、相当プログラムの経験とロジックを使いなれないと作ることもできないかもしれない。(聞いている人の能力と関係する。)
○ワークシート関数は、自動反映を期して、シートの1箇所変わると、全部の式が関係あるかチェックし、計算するようです。
#5で紹介されいることぐらいは手を打つとして、できるものはバッチ処理方式を取り入れた計算や処理にすると良い場合がありそう。ソートなどを多用する、昔の方式ですが、処理に無駄が無い場合が多い。
○結局このような質問は、個別の問題であるので、質問者も回答に十分満足がなされないでしょう。自分で経験して会得するより無いでしょう。
多数の関数を使っている場合もあり、OKWAVEに質問も出しにくいでしょう。
>Excel関数をVBAの関数に変換できますか
#1の補足を見ても、表題は質問者の関心事を捕らえていないのでは。
文章どおり採ると、プログラム力が有ればできる、となってしまう。
機械的にセルのFormulaをWorkSheetFunctionをつけて実行できるかというと、VBAのワークシート関数の一覧か関数事典でVBAの表示の有無があるものがあり、参考になるでしょう。しかし自動変換というわけには行かないでしょう。
No.5
- 回答日時:
#02です。
VBAでワークシート関数を使用して処理時間がかかるようになったのなら、以下を試してみてください
VBA実行の最初に
Application.ScreenUpdating = False '画面描画の停止
Application.Calculation = xlManual '関数自動計算の停止
VBA終了時に
Application.ScreenUpdating = True '画面再描画の再開
Application.Calculation = xlAutomatic '関数再計算
効果があると思います
No.4
- 回答日時:
#1補>Excel関数が複雑すぎたためにパフォーマンスの劣化がおきてしまい…
エクセルのワークシートの関数で処理しているときに、
それぞれのセルは独立したプログラムみたいなものなので、
同じ範囲の演算を繰り返ししている場合があります。
そのような場合に、演算を1つにし結果を各セルに書き出すようにすれば、パフォーマンスを良くする可能性があると思います。
ひとつのセルにIFやらCOUNTやらを
大量に使ってあるのですが、その様な
セルがさらに大量にあります;
いざプログラムに落とそうとしたら
すごく大変になってしまったという経緯が
あります;
少しずつ分離して試して見ます。
ありがとうございます。
No.1
- 回答日時:
違っているかもしれませんが、仰りたいのは「ワークシート関数をVBAで使いたい」って事ですか?
それなら下記のサイトを参考にしてください。
参考URL:http://www.moug.net/tech/exvba/0100035.htm
この回答への補足
回答ありがとうございます。
参考にさせていただきました。
ただ、説明が不足していて申し訳ありませんが、
例えばSUM(A1、A2)がExcel関数であるとしたら
VBAで、for文の様な形で和を出すような(このレベル
になるとツールになるかもしれません;方法が一つ
ではないと思うので)ことはできるかどうかという
ことです。
目的としては、Excel関数が複雑すぎたために
パフォーマンスの劣化がおきてしまい、VBAで
計算した後にSheetに入れようと思いました。
処理速度的にはどこかのサイトで速くなる意味合い
のことをみました。(関数のVolumeにもよると思い
ますが)
回答してくださった方々のような、VBAでExcelの
関数を呼ぶ場合は速度的にはどのような感じに
なるでしょうか?
よろしくお願いします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) Excelについて質問です。 シート1の検索値例えば *ABC* をシート2.3.4から検索して、シ 5 2023/02/17 23:30
- その他(Microsoft Office) WordやExcelで英数字のみ半角または全角にしたい 6 2022/08/03 08:18
- Excel(エクセル) 重複したデータ(空白は除く)のVBA表記について 4 2022/08/15 07:28
- Visual Basic(VBA) VBAでPDFのアクティブページ番号取得 1 2023/05/25 12:41
- その他(Microsoft Office) SUMIFとCOUNTIFの違いについて 4 2022/09/29 14:13
- Visual Basic(VBA) VBA 検索と入力 Excel ブック ぶぶぶ シート ししし 列V 検索対象の列です 最終行は、お 6 2023/05/17 01:40
- Excel(エクセル) エクセル・スプレッドシートで、一定数を超えたらゼロから再累計する方法 8 2022/05/28 03:52
- Visual Basic(VBA) ExcelのVBAを使い、複数シートの同一箇所を、同一条件にて一括でソルバーを回す方法について 1 2022/04/23 11:49
- Excel(エクセル) Excelマクロの表示のExcel内をfindで検索 3 2022/06/15 20:07
- Excel(エクセル) excelの16進数表示方法 1 2022/12/02 10:51
このQ&Aを見た人はこんなQ&Aも見ています
-
これまでで一番「情けなかったとき」はいつですか?
これまでの人生で一番「情けない」と感じていたときはいつですか? そこからどう変化していきましたか?
-
初めて自分の家と他人の家が違う、と意識した時
子供の頃、友達の家に行くと「なんか自分の家と匂いが違うな?」って思いませんでしたか?
-
モテ期を経験した方いらっしゃいますか?
一生に一度はモテ期があるといいますが、みなさんどうですか? いまがそう! という方も、「思い返せばこの頃だったなぁ」という方も、よかったら教えて下さい。
-
テレビやラジオに出たことがある人、いますか?
テレビやラジオに取材されたり、ゲスト出演したことある方いますか?
-
14歳の自分に衝撃の事実を告げてください
タイムマシンで14歳の自分のところに現れた未来のあなた。 衝撃的な事実を告げて自分に驚かせるとしたら何を告げますか?
-
【Excel VBA】指定行以降をクリアするには?
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・一番好きなみそ汁の具材は?
- ・泣きながら食べたご飯の思い出
- ・「これはヤバかったな」という遅刻エピソード
- ・初めて自分の家と他人の家が違う、と意識した時
- ・いちばん失敗した人決定戦
- ・思い出すきっかけは 音楽?におい?景色?
- ・あなたなりのストレス発散方法を教えてください!
- ・もし10億円当たったら何に使いますか?
- ・何回やってもうまくいかないことは?
- ・今年はじめたいことは?
- ・あなたの人生で一番ピンチに陥った瞬間は?
- ・初めて見た映画を教えてください!
- ・今の日本に期待することはなんですか?
- ・集中するためにやっていること
- ・テレビやラジオに出たことがある人、いますか?
- ・【お題】斜め上を行くスキー場にありがちなこと
- ・人生でいちばんスベッた瞬間
- ・コーピングについて教えてください
- ・あなたの「プチ贅沢」はなんですか?
- ・コンビニでおにぎりを買うときのスタメンはどの具?
- ・おすすめの美術館・博物館、教えてください!
- ・【お題】大変な警告
- ・洋服何着持ってますか?
- ・みんなの【マイ・ベスト積読2024】を教えてください。
- ・「これいらなくない?」という慣習、教えてください
- ・今から楽しみな予定はありますか?
- ・AIツールの活用方法を教えて
- ・最強の防寒、あったか術を教えてください!
- ・歳とったな〜〜と思ったことは?
- ・モテ期を経験した方いらっしゃいますか?
- ・好きな人を振り向かせるためにしたこと
- ・スマホに会話を聞かれているな!?と思ったことありますか?
- ・それもChatGPT!?と驚いた使用方法を教えてください
- ・見学に行くとしたら【天国】と【地獄】どっち?
- ・これまでで一番「情けなかったとき」はいつですか?
- ・この人頭いいなと思ったエピソード
- ・あなたの「必」の書き順を教えてください
- ・14歳の自分に衝撃の事実を告げてください
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
EXCELで複数のシートを一度に「...
-
エクセルでブック内の倍率がバ...
-
特定のシートのみ再計算させな...
-
ハイパーリンクでジャンプした...
-
【ExcelVBA】マクロの入ったシ...
-
エクセル、特定のシートにパス...
-
確定申告用の医療費集計フォー...
-
Excelでマクロ設定したが反映さ...
-
エクセルで複数のシートに画像...
-
エクセルでリンク貼り付けした...
-
EXCELの図形(テキストボックス)...
-
Wordで差し込み印刷時に表示す...
-
Accessのテーブルを既存のExcel...
-
エクセルのシー名を二段表示に...
-
EXCELで存在しないシート...
-
(エクセル)Indirect関数で、ハ...
-
【Excel VBA】データ貼り付け先...
-
エクセルの2つのシートを並び...
-
エクセルのファイルサイズが急...
-
ワークシートそのものの色を変...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
EXCELで複数のシートを一度に「...
-
エクセルでブック内の倍率がバ...
-
ハイパーリンクでジャンプした...
-
特定のシートのみ再計算させな...
-
エクセルで複数のシートに画像...
-
【ExcelVBA】マクロの入ったシ...
-
EXCELの図形(テキストボックス)...
-
エクセルのシー名を二段表示に...
-
ワークシートそのものの色を変...
-
エクセル、特定のシートにパス...
-
確定申告用の医療費集計フォー...
-
EXCELの「シートの見出し」のフ...
-
Wordで差し込み印刷時に表示す...
-
Accessのテーブルを既存のExcel...
-
EXCELで存在しないシート...
-
エクセルの2つのシートを並び...
-
エクセルのシート連番の振り直し
-
Excelでマクロ設定したが反映さ...
-
エクセルで、シートの名前を変...
-
エクセルの複数シートでのリン...
おすすめ情報