質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

Q&A

3回答

9306閲覧

Vbaで書式のみ高速コピペ

baklava

総合スコア0

VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

0グッド

0クリップ

投稿2020/06/18 12:17

Vbaで書式のみ高速コピ ぺする方法を教えてください
例えば一行目の書式をコピーして、五行目から十行目に貼り付けるということは
Selection.pasteでできるのですが、
大量に実行する場合、遅くて使い物にならず、困っています。
よろしくお願いします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

hatena19

2020/06/18 12:43

現状のコードを提示してください。
baklava

2020/06/19 01:48 編集

ありがとうございます。 Dim wb as Workbook dim iMinHRow as long 'ペースト先の一番上の行、別途取得。 dim lRow as long 'ペースト先の一番下の行、別途取得。 Set wb = Workbooks.Open(ファイルパス) Debug.Print "start " & Now For m = 0 To UBound(strASub) strA = Split(Replace(strASub(m),":", ""), "$") iMinCol =AlphaToNum(strA(1)) iMaxCol =AlphaToNum(strA(3)) wb.Sheets("Sheet1").Range("$" & strA(1) & "$" & strA(2) & ":$" & strA(3) & "$" & strA(4)).Copy wb.Sheets("Sheet1").Range(strA(1) & iMinHRow & ":" & strA(3) & lRow).PasteSpecial Paste:=xlPasteFormats, Operation:=xlNone, SkipBlanks:=False, Transpose:=False Application.CutCopyMode = False wb.Sheets("Sheet1").Range("A1").Select Next Debug.Print "end " & Now strASubという配列の中に $C$2:$E$15 $F$2:$F$15 $G$2:$J$15 $K$2:$L$15 などと、複数の範囲が文字列で格納されているので、範囲ごとに書式コピペしているという動きです。 一部selectを外して改善されたのですが、これでも範囲により2秒かかることがあります。 コピペ対象のファイルが300くらいあることがあるので、なんとかならんかなと思っているところです。 AlphaToNumは自作の別関数ですが、ここは時間かかっていません。
hatena19

2020/06/19 04:51

質問は編集できますので、コードは質問に追記してください。その場合、コードはコードブロックにしてください。コード部分を選択して、ツールバーの <code>をクリックするとコードブロックになります。
guest

回答3

0

ExcelVBA

1Sub test() 2 Dim wb As Workbook 3 Dim rngFrom As Range 4 Dim rngTo As Range 5 Dim t 6 7 t = Timer 8 9 Set wb = Workbooks.Open(ファイルパス) 10 With wb.Sheets(1) 11 Set rngFrom = .Range("C1:E5") 12 Set rngTo = .Range("C2:L15") 13 end with 14 15 rngFrom.Copy 16 rngTo.PasteSpecial Paste:=xlPasteFormats 17 18  wb.close true 19 20 Debug.Print "end", Timer - t & " 秒" 21End Sub

とりあえず、こんな感じでいいのでは?

コピー元とコピー先の関係がよくわからないですが、
なんで、コピー先が細かく分かれているのでしょう?
あと、セルアドレスの$はあってもなくても影響がないので、
無理にばらしたり、無理にくっつけたりはしなくてもいいかと。

投稿2020/06/23 01:09

編集2020/06/23 01:11
mattuwan

総合スコア2163

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

取り扱うデータが、どのようなデータなのか、質問からは読み取れませんが、
大量データに対して、コピペをForステートメントなどの繰り返し文で行うのは、
良くない手法だと思います。

Excelには便利な機能を豊富に準備しています。
オートフィルタや並べ替えを組み合わせて使用する方法もあります。
条件付き書式設定も使えると思います。

おそらく、CSVファイルだと思います。
データの取得の機能で、データをリンクすることが可能です。
イメージ説明

今のExcelの機能は本当に充実しています。
機能で求められる結果がでる場合も多々あります。

投稿2020/06/22 13:40

kai_keitai

総合スコア344

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

高速化には、まずは、描画を停止する。

vba

1Application.ScreenUpdating = False ' 描画を停止する 2 3'高速化したい処理 4 5Application.ScreenUpdating = True ' 描画を再開する

次に、無駄なSelectはしない。

vba

1Range(”A1:C1”).Select 2Selection.Copy 3Range(”A5:C10”).Select 4Selection.PasteSpecial Paste:=xlPasteFormats

vba

1Range(”A1:C1”).Copy 2Range(”A5:C10”).PasteSpecial Paste:=xlPasteFormats

上記の対策をしても改善されない場合は、現状のコードを提示してください。

投稿2020/06/18 13:07

hatena19

総合スコア34075

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問