VBA技術解説
画像が行列削除についてこない場合の対処

ExcelマクロVBAの問題点と解決策、VBAの技術的解説
公開日:2021-06-04 最終更新日:2021-06-04

画像が行列削除についてこない場合の対処


複数ブック・複数シートを次々に処理していくようなVBAにおいて、
行削除や列削除をした時に、画像がセルの移動についてこない場合があります。


プロパティは、「セルに合わせて移動やサイズ変更をする」になっている場合です。

マクロ VBA 画像が移動しない

プロパティで「セルに合わせて移動する」になっているにも関わらず、画像が行列削除で移動しないといった現象が起こってしまう事があるという事です。


必ず現象が発生するわけではなく、
ブック・シートの状態(シート数と画像数)によって現象が発生することがあるという事になります。


具体的な発生状況

マクロブックから他のブックの全シートに対して、行削除や列削除を行っているVBA
Application.ScreenUpdating = Falseが入っている

このVBAを実行したところ、環境によって画像が移動する場合と移動しない場合が発生しました。

今回実際に発生した時点で、各バージョンでの挙動を確認したところ、
私の環境では
365:OK正しく動作
2019:OK正しく動作
2013:NG画像が移動せず
2010:NG画像が移動せず
しかし、納品先(顧客)の365ではNGで画像が移動しませんでした。
同じ365で挙動違いがでているのが不可解ではありますが、PCスペックも関係するでしょうからあり得ることだと思います。


画像が正しく移動しない場合の対処

このような場合の一般的な対処方法としては、
・DoEvents
・Application.Wait(Sleepでも良い)
・Application.ScreenUpdating = True

・ブックのActivate、シートのSelect

上の2つ、DoEventsとApplication.Waitは、Deleteの直後に入れることになります。

ただし、DoEventsで解決することはほとんど期待できないと思います。
Application.Waitで1~2秒程度待たせると上手くいくことが多いと思います。

しかし、案外確実なのは、
Application.ScreenUpdating = True
つまり、わざわざFalseにしなければ良いのです。
その上で、
当該ブックをActivateし、当該シートをSelectすれば、大抵の場合は正しく動作してくれるはずです。
Application.ScreenUpdating = False
これにするのは、処理速度向上ということで理解している人が多いと思います。
実際その通りではありますが・・・
画面描画が何度も繰り返し変化する場合に速度に大きく影響するという事です。
数十回程度の画面変化では、全体として待たされるというほどの感じは受けません。
行列削除が数回での時間差異は気にするようなものではありません。
ですから、例えば行削除であれば、連続している行はまとめて削除するようにしてください。
複数のセル範囲をまとめるには、ApplicationのUnionを使います。
第103回.UnionメソッドとAreasプロパティ|VBA入門
・Unionメソッド ・Areasプロパティ ・Unionメソッドで連結した結果のRangeオブジェクトの状態について ・Unionメソッドの使用例 ・Unionメソッドの実践例


VBAでは、時に不可解な挙動に悩まされる場合があります。
特に画像・図形の挙動は安定しない場合が多くあります。
そのような場合は先に挙げた、
・DoEvents
・Application.Wait(Sleepでも良い)
・Application.ScreenUpdating = True

・ブックのActivate、シートのSelect
これらを組み合わせて上手く対処していくことが必要になります。

※画像・図形のコピー貼り付けではエラーになってしまう場合が多くあります。
この場合はWaitで対処する事になりますが、どの程度待てば良いか等もはっきりしませんし確実に対処できるとも限りません。
どうしてもうまくいかない場合は、APIを使う事も検討してください。




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

入力規則への貼り付けを禁止する
Select Caseでの短絡評価(ショートサーキット)の使い方
RangeオブジェクトのFor EachとAreasについて
画像が行列削除についてこない場合の対処
新関数SORTBYをVBAで利用するラップ関数を作成
LAMBDA以降の新関数はVBAで使えるか
数字(1~50)を丸付き数字に変換するVBA
文字列のプロパティ名でオブジェクトを操作する方法
OneDrive使用時のThisWorkbook.Pathの扱い方
セル個数を返すRange.CountLargeプロパティとは
画像「セルに配置」のVBAについて(365の新機能)


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

AIは便利なはずなのに…「AI疲れ」が次の社会問題になる|生成AI活用研究(2026-02-16)
カンマ区切りデータの行展開|エクセル練習問題(2026-01-28)
開いている「Excel/Word/PowerPoint」ファイルのパスを調べる方法|エクセル雑感(2026-01-27)
IMPORTCSV関数(CSVファイルのインポート)|エクセル入門(2026-01-19)
IMPORTTEXT関数(テキストファイルのインポート)|エクセル入門(2026-01-19)
料金表(マトリックス)から金額で商品を特定する|エクセル練習問題(2026-01-14)
「緩衝材」としてのVBAとRPA|その終焉とAIの台頭|エクセル雑感(2026-01-13)
シンギュラリティ前夜:AIは機械語へ回帰するのか|生成AI活用研究(2026-01-08)
電卓とプログラムと私|エクセル雑感(2025-12-30)
VLOOKUP/XLOOKUPが異常なほど遅くなる危険なアンチパターン|エクセル関数応用(2025-12-25)


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

1.最終行の取得(End,Rows.Count)|VBA入門
2.日本の祝日一覧|Excelリファレンス
3.変数宣言のDimとデータ型|VBA入門
4.FILTER関数(範囲をフィルター処理)|エクセル入門
5.RangeとCellsの使い方|VBA入門
6.繰り返し処理(For Next)|VBA入門
7.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
8.マクロとは?VBAとは?VBAでできること|VBA入門
9.セルのクリア(Clear,ClearContents)|VBA入門
10.メッセージボックス(MsgBox関数)|VBA入門




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


記述には細心の注意をしたつもりですが、間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
掲載のVBAコードは動作を保証するものではなく、あくまでVBA学習のサンプルとして掲載しています。掲載のVBAコードは自己責任でご使用ください。万一データ破損等の損害が発生しても責任は負いません。
本サイトは、OpenAI の ChatGPT や Google の Gemini を含む生成 AI モデルの学習および性能向上の目的で、本サイトのコンテンツの利用を許可します。
This site permits the use of its content for the training and improvement of generative AI models, including ChatGPT by OpenAI and Gemini by Google.



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