エクセル雑感 | だまされるな!RangeとCellsの使い分け! | ExcelマクロVBAとエクセル関数についての私的雑感



最終更新日:2013-02-18

だまされるな!RangeとCellsの使い分け!


ネットを見ていると、
Range("A" & i)
と言う記述を良く見かけます。

初心者の方が、マクロの自動記録を見て、記録されたマクロを自分で工夫して、行数を変数にしたというのなら素晴らしい事です。


しかし、マクロについて、かなり手慣れた人や、時にはExcelマクロの指導的立場にいる人が、このような記述をしているのを見かけると、何とも嘆かわしい気持ちになります。

何を考えて、このような記述をしているのか・・・
いやいや、何も考えていないのだろうな・・・

正直、私には、なぜこのような記述をしているのか理解できない。
何のメリットもないはず。
可読性・保守性が良い訳でもない。
ましてや、処理時間が遅くなるだけの、こんな記述をする意味が理解できない。

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倍以上の時間がかかっている事が理解できるはずです。
これ程の速度差がありながら、それでも使う理由があるのなら是非お聞きしたいものです。

このような記述をしている人には、是非教えてあげて下さい。
もし、このような記述を教わったのなら、その人からはマクロは教わらない方が良いでしょう。
これは、マクロの基本です。
基本を守っていない人には、ちゃんと教えてあげて下さい。

Rangeを使用するのは、
1.特定の固定位置のセルを指定する場合
2.名前定義でセルを参照する場合
3.複数のセル範囲を指定する場合

1は、特定の固定位置のセルならば、可読性の点において良いでしょう。
2と3は、Rangeしか使えないので、当然よいですね。

しっかり、RangeとCellsの使い分けをして下さい。

また、時にOffsetをやたらと使う記述も見かけます。
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よりも遅いですよね。
それぞれ、使い場所というのがあります。
適切に使い分ける事で、可読性・保守性、そして速度アップ対策が出来るのです。

基本は大切です。

基本を守る事、それが可読性・保守性を高め、そして速度対策になるのです。





同じテーマ「エクセル雑感」の記事

エクセル関連ツイートNo2
エクセル(関数・マクロ)上達のコツ
エクセルVBAあるある
Excelマクロを書くのに○○力は必用か?
offset 検索ワードで非常に多いので「offsetまとめ」
Excelのリンクの管理について
プログラミングとは

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

空白セルを正しく判定する方法2|ExcelマクロVBA技術解説(5月6日)
フルパスをディレクトリ、ファイル名、拡張子に分ける|ExcelマクロVBA技術解説(4月15日)
テキストボックスの各種イベント|Excelユーザーフォーム入門(4月9日)
フォルダ(サブフォルダも全て)削除する、Optionでファイルのみ削除|ExcelマクロVBAサンプル集(4月4日)
最後の空白(や指定文字)以降の文字を取り出す|エクセル関数超技(3月26日)
先頭の数値、最後の数値を取り出す|エクセル関数超技(3月26日)
Excelファイルを開かずにシート名をチェック|ExcelマクロVBAサンプル集(3月23日)
数式の参照しているセルを取得する|ExcelマクロVBAサンプル集(3月18日)
CSVの読み込み方法(改の改)|ExcelマクロVBAサンプル集(3月17日)
変数とプロシージャーの命名について|ExcelマクロVBA技術解説(2月12日)

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

1.最終行の取得(End,Rows.Count)|ExcelマクロVBA入門
2.ひらがな⇔カタカナの変換|エクセル基本操作
3.RangeとCellsの使い方|ExcelマクロVBA入門
4.Range以外の指定方法(Cells,Rows,Columns)|ExcelマクロVBA入門
5.徹底解説(VLOOKUP,MATCH,INDEX,OFFSET)|エクセル関数超技
6.変数とデータ型(Dim)|ExcelマクロVBA入門
7.セルの参照範囲を可変にする(OFFSET,COUNTA,MATCH)|エクセル関数超技
8.セルのコピー&値の貼り付け(PasteSpecial)|ExcelマクロVBA入門
9.CSVの読み込み方法|ExcelマクロVBAサンプル集
10.定数と型宣言文字(Const)|ExcelマクロVBA入門



  • >
  • >
  • >
  • だまされるな!RangeとCellsの使い分け!

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


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




    ↑ PAGE TOP