だまされるな!RangeとCellsの使い分け!
ネットを見ていると、
Range("A" & i)
と言う記述を良く見かけます。
いやいや、何も考えていないのだろうな・・・
何のメリットもないはず。
可読性・保守性が良い訳でもない。
ましてや、処理時間が遅くなるだけの、こんな記述をする意味が理解できない。
このような記述を教えているとしたら、とんでもない事だ。
VBAの基本がまるで分っていないとしか言えない。
以下のテストコードを比べてみてもらいたい。
Sub test1()
Debug.Print Timer
Dim str As String
Dim i As Long
For i = 1 To 1000000
str = Range("A" & i)
Next
Debug.Print Timer
End Sub
Sub test2()
Debug.Print Timer
Dim str As String
Dim i As Long
For i = 1 To 1000000
str = Cells(i, 1)
Next
Debug.Print Timer
End Sub
実行して、処理時間の違いを確認してもらいたい。
このRangeは、2.5倍以上の時間がかかっている事が理解できるはずです。
これ程の速度差がありながら、それでも使う理由があるのなら是非お聞きしたいものです。
もし、このような記述を教わったのなら、その人からはマクロは教わらない方が良いでしょう。
これは、マクロの基本です。
基本を守っていない人には、ちゃんと教えてあげて下さい。
1.特定の固定位置のセルを指定する場合
2.名前定義でセルを参照する場合
3.複数のセル範囲を指定する場合
2と3は、Rangeしか使えないので、当然よいですね。
Offsetは非常に便利で、是非使いこなしてもらいたいのですが、むやみに使うのは問題があります。
Offsetは、やはり処理速度が遅いのです。
以下のコードで確認してみて下さい。
Sub test3()
Debug.Print Timer
Dim str As String
Dim i As Long
For i = 1 To 1000000
str = Range("A1").Offset(i)
Next
Debug.Print Timer
End Sub
どうですか、先のRangeよりも遅いですよね。
それぞれ、使い場所というのがあります。
適切に使い分ける事で、可読性・保守性、そして速度アップ対策が出来るのです。
同じテーマ「エクセル雑感」の記事
もしエクセルにマクロ機能がなかったら
物事には守るべき順序があります。エクセルにも順序があります。
Excelマクロ実行時のトラブル対処方法
だまされるな!RangeとCellsの使い分け!
エクセル(関数・マクロ)上達のコツ
エクセルVBAあるある
Excelマクロを書くのに○○力は必用か?
「offsetまとめ」検索ワードで非常に多いoffset
Excelのリンクの管理について
プログラミングとは
「ネ申Excel」問題 への同意と反論
新着記事NEW ・・・新着記事一覧を見る
イータ縮小ラムダ(eta reduced lambda)|エクセル入門(2023-11-20)
PIVOTBY関数(縦軸と横軸でグループ化して集計)|エクセル入門(2023-11-19)
GROUPBY関数(縦軸でグループ化して集計)|エクセル入門(2023-11-18)
PY関数(Pythonコードをセル内で実行)|エクセル入門(2023-11-17)
画像「セルに配置」のVBAについて(365の新機能)|VBA技術解説(2023-11-13)
スピルのゴーストの範囲を選択するVBA|ツイッター出題回答 (2023-10-31)
エクセル試験3:月間の所定労働時間|エクセル練習問題(2023-10-04)
エクセル試験2:所得税の計算|エクセル練習問題(2023-10-04)
エクセル試験1:曜日別の平均客単価|エクセル練習問題(2023-10-04)
列全体を指定する時のRangeとColumnsの違い|ツイッター出題回答 (2023-09-24)
アクセスランキング ・・・ ランキング一覧を見る
1.最終行の取得(End,Rows.Count)|VBA入門
2.RangeとCellsの使い方|VBA入門
3.繰り返し処理(For Next)|VBA入門
4.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
5.変数宣言のDimとデータ型|VBA入門
6.条件分岐(IF)|VBA入門
7.ブックを閉じる・保存(Close,Save,SaveAs)|VBA入門
8.並べ替え(Sort)|VBA入門
9.マクロとは?VBAとは?VBAでできること|VBA入門
10.Range以外の指定方法(Cells,Rows,Columns)|VBA入門
このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。
記述には細心の注意をしたつもりですが、
間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
掲載のVBAコードは動作を保証するものではなく、あくまでVBA学習のサンプルとして掲載しています。
掲載のVBAコードは自己責任でご使用ください。万一データ破損等の損害が発生しても責任は負いません。