第41回.セルのコピー&値の貼り付け(PasteSpecial)
値の貼り付けと題しましたが、値だけではなく、「形式を選択して貼り付け」のいろいろな指定方法です。
セルをコピーして、他のセルに「形式を選択して貼り付け」する場合のマクロVBAコードになります。
Range.PasteSpecial(Paste, Operation, SkipBlanks, Transpose)
名前 | 指定値 | 説明 |
Paste | xlPasteAll | すべてを貼り付けます。 |
xlPasteAllExceptBorders | 輪郭以外のすべてを貼り付けます。 | |
xlPasteAllMergingConditionalFormats | すべてを貼り付け、条件付き書式をマージします。 | |
xlPasteAllUsingSourceTheme | ソースのテーマを使用してすべてを貼り付けます。 | |
xlPasteColumnWidths | コピーした列の幅を貼り付けます。 | |
xlPasteComments | コメントを貼り付けます。 | |
xlPasteFormats | コピーしたソースの形式を貼り付けます。 | |
xlPasteFormulas | 数式を貼り付けます。 | |
xlPasteFormulasAndNumberFormats | 数式と数値の書式を貼り付けます。 | |
xlPasteValidation | 入力規則を貼り付けます。 | |
xlPasteValues | 値を貼り付けます。 | |
xlPasteValuesAndNumberFormats | 値と数値の書式を貼り付けます。 | |
Operation | xlPasteSpecialOperationAdd | コピーしたデータは、対象セルの値に追加されます。 |
xlPasteSpecialOperationDivide | コピーしたデータは、対象セルの値によって分割されます。 | |
xlPasteSpecialOperationMultiply | コピーしたデータには、対象セルの値が掛けられます。 | |
xlPasteSpecialOperationNone | 貼り付け操作で計算は行われません。 | |
xlPasteSpecialOperationSubtract | コピーしたデータは、対象セルの値が引かれます。 | |
SkipBlanks | バリアント型 (Variant) | クリップボードに含まれる空白のセルを貼り付けの対象にしないようにするには、True を指定します。 既定値は False です。 |
Transpose | バリアント型 (Variant) | 貼り付けのときにデータの行と列を入れ替えるには、True を指定します。 既定値は False です。 |
値の貼り付
Worksheets("Sheet2").Range("A1").PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks:=False, Transpose:=False
このように記述します。
前回のPasteとは違い、アクティブシート以外にも貼り付けが可能です。
従って、
Paste:=xlPasteAll
これなら、セルの全てがコピーされるので、Pasteと同じになります。
いろいろなコピーのVBAの書き方
Sheets("Sheet1").Select Range("A1:B10").Copy |
Sheets("Sheet1").Range("A1:B10").Copy Destination:=Sheets("Sheet2").Range("A1") |
Sheets("Sheet1").Range("A1:B10").Copy |
これら3つのコードは、同じことをしています。
マクロVBAでよく使うものとしては、
Paste:=xlPasteValues ・・・ 値を貼り付け
Transpose:=True ・・・ 行と列を入れ替え
このあたりは、しっかり使えるようにしておきましょう。
使用例
Sheet2のA1に、行列を入れ替えて値を貼り付けします。
Worksheets("Sheet1").Range("A1:B10").Copy Worksheets("Sheet2").Range("A1").PasteSpecial Paste:=xlPasteValues, Transpose:=True |
マクロVBAで、セルのコピペは必須になります。
次回の、
第42回.セルをコピーするとは
こちらと合わせて、ぜひ、しっかりと覚えて下さい。
同じテーマ「マクロVBA入門」の記事
第38回.セルに計算式を設定(Formula)
第39回.セルのクリア(Clear,ClearContents)
第40回.セルのコピー・カット&ペースト(Copy,Cut,Paste)
第41回.セルのコピー&値の貼り付け(PasteSpecial)
第42回.セルをコピーするとは
第43回.総合練習問題5
第44回.VBA関数について
第45回.VBA関数(Format)
第46回.VBA関数(日付,DateAdd)
第47回.VBA関数(文字列操作,Replace,InStr,StrConv)
第48回.VBA関数(その他,Fix,Int,Rnd,Round,IsEmpty)
新着記事 ・・・新着記事一覧を見る
Excelシートの複雑な計算式を解析するVBA|VBAサンプル集(2月18日)
VBAクラスの作り方:独自Rangeっぽいものを作ってみた|VBA技術解説(2月16日)
VBAクラスの作り方:列名のプロパティを自動作成する|VBA技術解説(2月14日)
VBAクラスの作り方:列名の入力支援と列移動対応|VBA技術解説(2月11日)
クラスを使って他ブックのイベントを補足する|VBA技術解説(2月6日)
Excelアドインの作成と登録について|VBA技術解説(2月3日)
参照設定、CreateObject、オブジェクト式の一覧|VBA技術解説(1月20日)
VBAでファイルを規定のアプリで開く方法|VBA技術解説(1月20日)
ドキュメントプロパティ(BuiltinDocumentProperties,CustomDocumentProperties)|VBA技術解説(1月19日)
他ブックへのリンクエラーを探し解除|VBAサンプル集(1月15日)
アクセスランキング ・・・ ランキング一覧を見る
1.最終行の取得(End,Rows.Count)|VBA入門
2.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
3.変数とデータ型(Dim)|ExcelマクロVBA入門
4.Range以外の指定方法(Cells,Rows,Columns)|VBA入門
5.RangeとCellsの使い方|ExcelマクロVBA入門
6.マクロって何?VBAって何?|ExcelマクロVBA入門
7.繰り返し処理(For Next)|ExcelマクロVBA入門
8.とにかく書いて見よう(Sub,End Sub)|VBA入門
9.定数と型宣言文字(Const)|ExcelマクロVBA入門
10.ひらがな⇔カタカナの変換|エクセル基本操作
このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。
記述には細心の注意をしたつもりですが、
間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
なお、掲載のVBAコードは自己責任で使ってください。万一データ破損等の損害が発生しても責任は負いません。