
No.2
- 回答日時:
そうですか? 不思議ですね。
短いコードなら提示するといいでしょうが
何をどうしているのか読む側にはわからないので
VBAコード以外に、一般機能で使っている関数も書いてみるといいかもしれません。
あと、Worksheet_SelectionChangeイベントだとしたら、
多量のデータの書き換えなどのためには使わないほうがいいかと。
CommandButtonクリックで開始するのでは都合が悪いのですか?
この回答への補足
ご回答ありがとうございます。
今回の処理内容を簡単に説明に説明すると、
複数のセルに入っている値を空白セルと重複セルを除外して、
全てつなぎ合わせて別セルに表示するといった内容です。
CONCATENATEや&でつなぐにはセル数が多すぎまるため、
VBAで処理をしています。
そのほか、
VLOOKUPで他シートからデータを引っ張るというセルが7000個ほどあります。
再計算に時間がかかっているのはおそらくこれが原因だと思っています。
ただ、今回の処理で再計算が自動でかからなくて困るということは無いので、
今回の処理をするときだけ再計算をしないようにしたかったのです。
ちなみにWorksheet_SelectionChangeではなくWorksheet_Changeです。
CommandButtonも考えましたが、あくまで最終手段ということで、
なるべくChangeイベント時に処理したいと思っています。
No.1
- 回答日時:
こんにちは。
イベント無効の
Application.EnableEvents = False
を入れてみては。
参考URL
http://vba.ti-da.net/e2482933.html
http://www.eurus.dti.ne.jp/yoneyama/Excel/vba/vb …
デバック、戻し忘れの回避策
http://d.hatena.ne.jp/tiri_tomato/20110910/13156 …
Changeイベントで
with Application
.EnableEvents = False 'イベント無効
.Calculation = xlCalculationManual '←再計算の設定を手動
.ScreenUpdating = False '←画面の再描画をOFFにする
end with
~処理~
with Application
.Calculation = xlCalculationAutomatic '←再計算の設定を自動
.ScreenUpdating = True '←画面の再描画をONにする
.EnableEvents = True'イベント有効
end with
この回答への補足
ご回答ありがとうございます。
Application.EnableEventsも試してみてはいました。
しかしながら、処理の一番頭にブレークポイントを設定して試してみたところ、
セルの値を変更(Worksheet_Changeイベント発生)
↓
再計算がかかる。
↓
Worksheet_Change内の処理が始まる。
(Application.EnableEvents = falseやApplication.Calculation = xlCalculationManualが走る)
なので、どうにもこうにもいかない状態です。
セルの値を変更するときは、あらかじめ再計算を手動にしておけばいいんでしょうが、
いちいちオプションや別のボタンを押して手動にしておくというのも、
あまり実用的ではないかなと思いまして・・・。
やはりCommandButtonをトリガーにするしかないのでしょうか。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) ネットワーク上のエクセルとリンクしている時にデータ更新をvbaで、refresh Allで行う場合の 2 2023/04/10 05:39
- Java java 飾子を付けること(public static・・・) ・コンソールへの出力処理はmainメ 2 2022/06/16 19:34
- 情報処理技術者・Microsoft認定資格 応用情報処理技術者試験のシステム利用率の計算について 2 2022/03/28 07:43
- その他(プログラミング・Web制作) プログラミング 処理速度 1 2022/11/25 11:05
- その他(IT・Webサービス) 高速処理可能な表計算ソフトについて ExcelやGoogleスプレッドシートのような表計算ソフトで、 2 2023/04/29 16:06
- Java javaの質問です 次の機能を有するメソッド4つを自クラスに作成し、実装したいです 【機能】 足し算 1 2022/06/15 17:49
- Visual Basic(VBA) エクセルVBA コードが同じでもファイルによって処理速度が大きく変わるのはなぜ 5 2022/11/06 21:34
- 数学 図はn=8の場合だけど、3段(=log[2]8)のバタフライ (3回の計算)で処理してる。と言われた 4 2022/03/24 19:41
- Excel(エクセル) マクロで謎の現象が起きていて困ってます。 エクセルで作ったボタンを押すとマクロが動いて処理をしてくれ 3 2023/06/22 17:28
- C言語・C++・C# numpyスライス機能を使った数値計算 2 2023/05/08 16:01
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
【C#/Java?】try-catchでcatch...
-
private subモジュールを他のモ...
-
どうやってもFor文を抜けてしま...
-
シグナル 6(SIGABRT)とは?
-
マクロで、次のコードへ行く前...
-
Word VBA。各マクロの間に待ち...
-
特定の名前のオートシェイプの...
-
IF文に時間(何時から何時ま...
-
C言語のGOTO文(組み込み系)
-
Excel VBA セルの名前があるか...
-
UWSCのTHREADについて
-
VB6.0で、ランタイムエラーを全...
-
エクセルVBAでロックをかけたい
-
¥マークを含むパスの処理につ...
-
フォルダのアクセス権確認について
-
Access プログレスバー 画面...
-
VBA For Each 〜 複数条件について
-
Functionで戻り値を複数返す方法
-
ドリブン??
-
VBA 複数の行を高速で削除する...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
【C#/Java?】try-catchでcatch...
-
vbaのエラー対応(実行時エラー...
-
シグナル 6(SIGABRT)とは?
-
どう増強すべきか
-
private subモジュールを他のモ...
-
IF文に時間(何時から何時ま...
-
特定の名前のオートシェイプの...
-
Excel VBA セルの名前があるか...
-
マクロで、次のコードへ行く前...
-
ExcelのVBAで、選択したファイ...
-
特定のファイルを他のプロセス...
-
VB6にてネットワーク上にある共...
-
どうやってもFor文を抜けてしま...
-
Word VBA。各マクロの間に待ち...
-
エクセル VBAで複数セル選択時...
-
【VBA】エラー処理で別プロシー...
-
フォルダのアクセス権確認について
-
VBA For Each 〜 複数条件について
-
StatusStripの表示が更新されな...
-
【C#】Page_Loadさせない方法に...
おすすめ情報