
お世話になります。
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で質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
今、見られている記事はコレ!
-
弁護士が解説!あなたの声を行政に届ける「パブリックコメント」制度のすべて
社会に対する意見や不満、疑問。それを発信する場所は、SNSやブログ、そしてニュースサイトのコメント欄など多岐にわたる。教えて!gooでも「ヤフコメ民について」というタイトルのトピックがあり、この投稿の通り、...
-
弁護士が語る「合法と違法を分けるオンラインカジノのシンプルな線引き」
「お金を賭けたら違法です」ーーこう答えたのは富士見坂法律事務所の井上義之弁護士。オンラインカジノが違法となるかどうかの基準は、このように非常にシンプルである。しかし2025年にはいって、違法賭博事件が相次...
-
釣りと密漁の違いは?知らなかったでは済まされない?事前にできることは?
知らなかったでは済まされないのが法律の世界であるが、全てを知ってから何かをするには少々手間がかかるし、最悪始めることすらできずに終わってしまうこともあり得る。教えてgooでも「釣りと密漁の境目はどこです...
-
カスハラとクレームの違いは?カスハラの法的責任は?企業がとるべき対応は?
東京都が、客からの迷惑行為などを称した「カスタマーハラスメント」、いわゆる「カスハラ」の防止を目的とした条例を、全国で初めて成立させた。条例に罰則はなく、2025年4月1日から施行される。 この動きは自治体...
-
なぜ批判コメントをするの?その心理と向き合い方をカウンセラーにきいた!
今や生活に必要不可欠となったインターネット。手軽に情報を得られるだけでなく、ネットを介したコミュニケーションも一般的となった。それと同時に顕在化しているのが、他者に対する辛らつな意見だ。ネットニュース...
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
「段」と「行」の違いがよくわ...
-
VLOOKUPの列番号の最大は?
-
VBA 指定した列にある日時デー...
-
エクセルで最初の行や列を開け...
-
vba マージエリアの行数を非表...
-
エクセルマクロPrivate Subを複...
-
エクセルのソートで、数字より...
-
LEFT関数とIF関数の組み合わせ...
-
エクセルで離れた列を選択して...
-
エクセルで?
-
Excelの行数、列数を増やしたい...
-
VBAで結合セルを転記する法を教...
-
データシートビューのタイトル...
-
別のブック最終行最終列の次へ...
-
エクセル 重複したデータを別...
-
列方向、行方向の定義
-
エクセル マクロ 範囲の値を上...
-
Excel で、二つの表の値が条件...
-
Excel 区切り位置指定ウィザー...
-
Excel文字列一括変換
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
「段」と「行」の違いがよくわ...
-
エクセルで離れた列を選択して...
-
VLOOKUPの列番号の最大は?
-
VBAで別ブックの列を検索し、該...
-
VBA 指定した列にある日時デー...
-
列方向、行方向の定義
-
LEFT関数とIF関数の組み合わせ...
-
Excelの行数、列数を増やしたい...
-
CSVファイルの「0落ち」にVBA
-
エクセル マクロ 範囲指定で...
-
VBAで結合セルを転記する法を教...
-
土日の列幅の自動変更を教えて...
-
ListViewで列を指定して表示さ...
-
エクセルで最初の行や列を開け...
-
エクセル マクロ 範囲の値を上...
-
csvデータの列の入れ替えができ...
-
最近急にVBAの処理速度が遅くな...
-
Excel文字列一括変換
-
エクセルで複数列の検索をマク...
-
エクセルのソートで、数字より...
おすすめ情報
範囲指定の部分ですが、
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……と列が続く限り繰り返します。
よろしくお願いいたします。