ExcelマクロVBA技術解説
Excel2013におけるScreenUpdatingの問題点

ExcelマクロVBAの問題点と解決策、エクセルVBAの技術的解説
最終更新日:2015-01-23

Excel2013におけるScreenUpdatingの問題点

今現在、Excelの最新バージョンであるExcel2013ですが、
Application.ScreenUpdating
の動作が、それまでとは違ったものになっています。


Microsoftサポートにも掲載されています。
Excel 2013 で複数のブックを開き Appliction.ScreenUpdating プロパティ使用中にアクティブ ブックが切り替わるとウィンドウが点滅しデスクトップが見えることがある

つまりは、複数ブックを開いて、ウインドウが切り替わるときは、
Application.ScreenUpdating = False
を入れていても、画面がチラつくというものです。

対策としてまず考えられるのが、
DoEvents
を入れる事になりますし、上記でも対策として書かれています。
が、しかし、上手くいくときもあるようですが、ほとんどの場合はダメですね。
そもそも、
ThisWorkbook.Activate
とかで、ウインドウが正しく切り変わりません。 個別の対応方法はあったとしても、こうすれば良いというものが存在していないようです。
少なくとも、私のテストでは統一的な解決策は見つけられませんでした。

結論を言うと、諦めましょうということになります。

どうしても、チラつくのが嫌だということなら、
Application.WindowState = xlMinimized
で最小化してしまうとかの方が早いと思います。
もしくは、
New Excel.Application
で新規インスタンスを生成して、そこに別ブックを読み込むとかでしょうか。
しかし、余程の事情がない限り、あまり余計なことをしない方が良いでしょうね、
逆にドツボにはまる可能性もありますから。

できれば、Microsoftが変更してくれることを願いますが、
先のページの文章を見る限り、これは仕様なのでしようがないということらしいです。



同じテーマ「マクロVBA技術解説」の記事

入力規則のドロップダウンが消えてしまうマクロ(Shapes内のDrop Down)

シートのShapeを全削除すると、入力規則のリストのドロップダウンが消えてしまいます。入力規則のリストのドロップダウンの設定については、エクセル入門.入力規則.リスト こちらを参照して下さい。入力規則のリストのドロップダウンが消えてしまう具体的なマクロは、以下のようなVBAコードになります。
実行時にトラップ可能なエラー番号一覧
VBA実行時に発生するエラーのうち以下の表にあるエラーはトラップ(捕捉)できるエラーになります。OnErrorステートメントおよびErrオブジェクトのNumberロパティを使用してエラーへの対処を行うことができます。VBAでのエラーとは 上記の結果はイミディエイトウインドウに 13 型が一致しません。
フォルダー・ファイル(ブック)・シートの文字制限
フォルダーの作成、ファイルの作成、ブックの作成、シートの作成、この時に指定できない文字があります、使用可能な文字に制限があります、シートの文字制限について間違った解説が結構見受けられます。フォルダ・ファイル・ブックの文字制限 使用不可文字は以下になります。
Excel2013におけるScreenUpdatingの問題点
Dir関数の制限について
VBAでフォルダ・ファイルの存在確認や、一覧取得において使われる関数ですが、いくつかの使用上の注意点、制限事項があります。・3桁拡張子の指定時の問題 このように指定した場合、xlsxやxlsmも対象となります。3桁の拡張子を指定した場合は、4桁の拡張子も対象となります。
よくあるVBA実行時エラーの解説と対応
VBAを書き終えて、いざ実行したら意味不明なメッセージが… ここでは初心者向けに、代表的な実行時エラーの解説とその対応について説明します。中級者以上の方は、実行時にトラップ可能なエラー番号一覧と対処 こちらを参考に、エラー対応(OnError等)を実装してください。
Application.Goto使用時の注意
Applicationのメソッドに、Gotoメソッドがあります、Application.Gotoメソッドは、指定ブックの、指定シートの、指定セル範囲を選択します、そのブック・シートがアクティブでなければアクティブにします。最初に、Application.Gotoの一般的な文法説明をします。
ScreenUpdating=False時にエラー停止後にシートが固まったら
VBAでは処理の高速化や画面チラつきを防ぐためにApplication.ScreenUpdating=False これを入れていることが多いと思います。これが入っているとVBAがエラーで停止してそこで「リセット」した場合にExcelシートをクリック出来なくなったりシートタブの切り替えができなくなってしまう場合があります。
標準スタイル違いの問題点:標準フォント複写、列幅をピクセルで合わせる
VBAでスタイルの標準フォントが違うブック間のコピー等の処理では、列幅や行高の違いが問題となる場合があります。列幅や行高は、標準スタイルの1文字分を基本としているためです。上の画像は、標準フォントが違うブックにおいて、同じ列幅20の時の、列幅の表示です。


新着記事NEW ・・・新着記事一覧を見る

Byte配列と文字コード関数について|VBA技術解説(8月20日)
PowerQueryの強力な機能をVBAから利用する方法|VBA技術解説(8月4日)
練習問題31(セル結合を解除して値を埋める)|VBA練習問題(7月30日)
練習問題30(マトリックス→リスト形式)|VBA練習問題(7月25日)
Applicationを省略できるApplicationのメソッド・プロパティ一覧|VBA技術解説(7月22日)
コレクション(Collection)の並べ替え(Sort)に対応するクラス|VBA技術解説(7月20日)
CSVの読み込み方法(ジャグ配列)|VBAサンプル集(7月15日)
その他のExcel機能(グループ化、重複の削除、オートフィル等)|VBA入門(7月14日)
オートフィルタ退避回復クラスを複数シート対応させるVBAクラス|VBA技術解説(7月6日)
オートフィルタを退避回復するVBAクラス|VBA技術解説(7月6日)


アクセスランキング ・・・ ランキング一覧を見る

1.最終行の取得(End,Rows.Count)|VBA入門
2.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
3.RangeとCellsの使い方|ExcelマクロVBA入門
4.Range以外の指定方法(Cells,Rows,Columns)|VBA入門
5.変数とデータ型(Dim)|ExcelマクロVBA入門
6.繰り返し処理(For Next)|ExcelマクロVBA入門
7.マクロって何?VBAって何?|ExcelマクロVBA入門
8.セルに文字を入れるとは(Range,Value)|VBA入門
9.ひらがな⇔カタカナの変換|エクセル基本操作
10.空白セルを正しく判定する方法(IsEmpty,IsError,HasFormula)|VBA技術解説



  • >
  • >
  • >
  • Excel2013におけるScreenUpdatingの問題点

  • このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。


    記述には細心の注意をしたつもりですが、
    間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
    なお、掲載のVBAコードは自己責任で使ってください。万一データ破損等の損害が発生しても責任は負いません。




    このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。
    本文下部へ