下記3つのコードを作りました。
sample3は、コピー、貼り付けの操作を1回で行っているので、一瞬で処理が終わります。
しかし、sample1では数十秒もかかってしまいます。また、sample2については、1秒程度です。sample1とsample2とでは、どうしてこのような処理速度の違いが出るのでしょうか。
実際の使用場面では、複数のセルをまとめてコピーする事はなく、条件に該当するセルが見つかったら、そのデータを他のシートの指定したセルに値のみを貼り付ける使い方をします。
その場合、処理速度の短縮をするには、下記コード、または、その他の方法でどのようにコピー貼り付けをするのがいいのでしょうか。
ご回答よろしくお願いします。
Sub sample1()
Dim i As Integer
For i = 1 To 10000
Cells(i, 1).Copy
Cells(i, 2).PasteSpecial Paste:=xlPasteValues
Next
End Sub
Sub sample2()
Dim i As Integer
For i = 1 To 10000
Cells(i, 2) = Cells(i, 1)
Next
End Sub
Sub sample3()
Dim i As Integer
Range(Range("a1"), Range("a1").End(xlDown)).Copy
Range("b1").PasteSpecial Pase:=xlPasteValues
Application.CutCopyMode = False
End Sub
No.1ベストアンサー
- 回答日時:
sample1 と sample2 の違い
Copyは、セルの塗りつぶし等セルの情報の全てメモリーに入れます。
処理が2行あります。
Cells(i, 2) = Cells(i, 1) は
Cells(i, 2) .Value= Cells(i, 1).Value を省略していますので値だけの情報です。
処理も一行ですんでいます。
sample1、sample2 と sample3 の違い
繰返しがありません。
最もパソコンに負担をかけないのは
Sub sample3()
Range("B1:B" & Range("a1").End(xlDown).Row).Value=Range("A1:A" & Range("a1").End(xlDown).Row).Value
End Sub
では、ないでしょうか。
これでも、Range("a1").End(xlDown).Row を二度実行しているので
変数に入れた方が良いのか、どうかは微妙な所です。
「.PasteSpecial Paste:=」の部分で、いろいろな貼り付け方法が指定できるので、「Copy」はセルのすべての情報をコピーするということになり、その分、負荷がかかるのですね。
教えて頂いたコードを実行すると、一瞬で処理が終わりました。「=」は、値をメモリーに入れずに処理をしているので早く処理が出来るのですね。
ご回答ありがとうございます。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
- ・ゆるやかでぃべーと タイムマシンを破壊すべきか。
- ・歩いた自慢大会
- ・許せない心理テスト
- ・字面がカッコいい英単語
- ・これ何て呼びますか Part2
- ・人生で一番思い出に残ってる靴
- ・ゆるやかでぃべーと すべての高校生はアルバイトをするべきだ。
- ・初めて自分の家と他人の家が違う、と意識した時
- ・単二電池
- ・チョコミントアイス
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Excelの警告について
-
タイムスタンプとテキストから...
-
シートの情報を別のシートへま...
-
マクロの処理が遅くなった
-
Excelでの文字色
-
ワークシートに出現したこの画...
-
EXCELの散布図で日付が1900年に...
-
OFFSET関数を使用したいのです...
-
エクセルでファイルの最終更新...
-
エクセルの文字が途中から消える
-
エクセルデーターから必要な項...
-
Excel 大小比較演算子による「...
-
SUBTOTALは、参照された数字で...
-
エクセルの数式バーのフォント...
-
エクセルの「条件付き書式」を...
-
Excelについて教えてください。...
-
エクセルVBA 月の中で、月~土...
-
Excelの数字の前に入っている空...
-
Excelの関数について このよう...
-
セルの数を求めたい
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
EXCEL2007 各行列にmedian関数...
-
Excel・Word リサーチ機能を無...
-
特定のPCだけ動作しないVBAマク...
-
UserForm1.Showでエラーになり...
-
エクセルで特定の列が0表示の場...
-
配列数式の解除
-
教えて下さい
-
Excel マクロ VBA プロシー...
-
メッセージボックスのOKボタ...
-
一つのTeratermのマクロで複数...
-
VBAでfunctionを利用しようとし...
-
ExcelのVBA。public変数の値が...
-
エクセルに張り付けた写真のフ...
-
Excel VBAからAccessマクロを実...
-
End Sub が必要です。
-
TERA TERMを隠す方法
-
【VBA】ワークブックを開く時に...
-
文字列内で括弧を使うには
-
Excel マクロでShearePoint先の...
-
Pythonでの文字列からfloatへの...
おすすめ情報