
お世話になります。
Excel2016にて作業をしておりますが、上手くいかないのでお知恵をお貸しいただきたく質問いたします。
【概要】
ピボットテーブルの範囲指定を変数にしたい
【詳細】
"データ貼付"というシートに、下図のようにデータが並んでいます。
A列とB列、C列とD列、E列とF列……というように2列ずつのデータがセットになっており、
セットごとにデータの個数が異なるこの2列を1つのピボットテーブルにしたいと考えています。
A列 B列 C列 D列 E列 F列……
1行目 A B C D E F
2行目 A B C D E F
3行目 A B C D E F
4行目 A B C D E F
5行目 A B E F
sourceArea = "データ貼付!A2:B" & Sheets("データ貼付").Cells(Rows.Count, "A").End(xlUp).Row
現状範囲指定がこのようになっていますが、この「A2:B」をC2:D、E2:F……と繰り返したい場合に、
どのように指定すればよいかわからずにおります。
ご助言をいただけますと大変ありがたいです。よろしくお願いいたします。
No.1ベストアンサー
- 回答日時:
こんにちは
>範囲指定を変数にする
とのご質問ですが、すでに変数(sourceArea)にはなさっているようなので・・
この値をどのように求めたら良いのか(計算処理したら良いのか)という意味と解釈しました。
>……と繰り返したい場合に、
とありますが、どのような繰り返しの方法を用いていらっしゃるのか不明なので、勝手に列に対するループとして以下に例を示しておきます。
必要になるのは、セル範囲を示す文字列でしょうから、そちらを直接求める方法に変えています。
以下は、2列毎を1セットにして、その「左側の列を基準にした最終行までの範囲」を表す文字列を順に表示する例です。
(変数 cellRange にセル範囲の文字列を代入しています)
Sub Sample()
For col = 1 To Cells(1, Columns.Count).End(xlToLeft).Column Step 2
cellRange = Cells(1, col).Resize(Cells(Rows.Count, col).End(xlUp).Row, 2).Address
MsgBox "第" & col & "列の範囲: " & cellRange
Next col
End Sub
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) コード名シートA列と集計シートA列のコードが一致したら、コード名シートA5からk12の範囲をコピーし 1 2022/08/29 23:46
- その他(Microsoft Office) マクロVBAについて 1 2022/09/06 18:12
- Visual Basic(VBA) 集計シートA列のコードと一致する右に並んだシート名(コード)の3行目から10行目をコピーして貼り付け 4 2022/08/18 15:24
- Visual Basic(VBA) vba 等間隔の列に対しての計算 6 2022/05/17 20:15
- Excel(エクセル) 【困っています】VBA 追加処理の記述を教えてください。 1 2022/08/25 22:54
- Visual Basic(VBA) VBAで、シート間の転記するコードをFOR~NEXTで教えてください。 9 2023/04/30 20:04
- Visual Basic(VBA) 3つのプロシージャをまとめたら実行時エラー発生で対応不能 6 2022/05/17 01:47
- Visual Basic(VBA) 【ご教示ください】VBAの記述方法がわかりません。 2 2022/08/12 21:28
- Visual Basic(VBA) 列と行の名前(重複あり)が交差するセルに、データを入力したい 3 2022/06/12 11:17
- Visual Basic(VBA) 4月~3月まで12カ月横に並んだ表へ指定範囲を貼り付けたい。 Sheet2の指定範囲、Range(" 2 2022/11/30 16:37
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
特定のセルだけ結果がおかしい...
-
エクセルのdatedif関数を使って...
-
エクセルのVBAで集計をしたい
-
【マクロ】【配列】3つのシー...
-
vba テキストボックスとリフト...
-
エクセル ドロップダウンリスト...
-
【関数】同じ関数なのに、エラ...
-
Office2021のエクセルで米国株...
-
【マクロ】列を折りたたみ非表...
-
9月17日でサービス終了らし...
-
【マクロ】アクティブセルの時...
-
ページが変なふうに切れる
-
【条件付き書式】シートの中で...
-
【マクロ】3行に上から下に並...
-
【マクロ】オートフィルターの...
-
【マクロ】EXCELで読込したCSV...
-
【画像あり】オートフィルター...
-
他のシートの検索
-
エクセルの循環参照、?
-
Excelファイルを開くと私だけVA...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
9月17日でサービス終了らし...
-
エクセル
-
【マクロ】WEBシステムから保存...
-
エクセルの循環参照、?
-
エクセル ドロップダウンリスト...
-
エクセルのdatedif関数を使って...
-
特定のセルだけ結果がおかしい...
-
【マクロ】A列にある、日付(本...
-
【マクロ】EXCELで読込したCSV...
-
【マクロ】アクティブセルの時...
-
【エクセル】期限アラートについて
-
iPhoneのExcelアプリで、別のシ...
-
【関数】同じ関数なのに、エラ...
-
Excelの新しい空白のブックを開...
-
【マクロ】3行に上から下に並...
-
【マクロ】宣言は、何のために...
-
VBA チェックボックスをオーバ...
-
Excelについての質問です 並べ...
-
【マクロ】アクティブセルの2...
-
【関数】不規則な文章から●●-●●...
おすすめ情報
範囲指定の部分ですが、
sourceArea = "データ貼付!A2:B" & Sheets("データ貼付").Cells(Rows.Count, "A").End(xlUp).Row
Dim pCashData As PivotCache
Set pCashData = ActiveWorkbook.PivotCaches.Create(SourceType:=xlDatabase, _
SourceData:=wsBaseName & "!" & sourceArea)
こんな感じで指定しています。
A2:Bで新しいシートにピボットテーブルを作成、次はC2:D、E2:F……と列が続く限り繰り返します。
よろしくお願いいたします。