いつもお世話になります。
エクセルファイルの中に約100シートあるのですが、新しいシートを用意して、100シートの中にある特定の位置のデータをそこに書き連ねていくことは出来ますでしょうか。ちなみにシートの名前は数値ではなく、地名を書き入れているので法則性はありません。
具体的な形としては、シート”大阪”、”堺”、”和泉”・・・とあって、各セルのA1、B2、C3のセルのデータが欲しかったとすれば、
地名,数値1,数値2,数値3
大阪,A1,B2,C3
堺,A1,B2,C3
和泉,A1,B2,C3
・・・
という表を作りたいのです。
どうか宜しくお願い致します。
No.1ベストアンサー
- 回答日時:
こんな時は
For Each ~ Next を使います。
Sub aaa()
'集計用のワークシートを作ります。
'既にある時はコメントアウト
Sheets(1).Select
Sheets.Add
ActiveSheet.Name = "集計"
Range("A1") = "地名"
Range("B1") = "数値1"
Range("C1") = "数値2"
Range("D1") = "数値3"
'ここから集計
Dim ws As Worksheet
Dim r As Integer
r = 1
For Each ws In Worksheets
If ws.Name <> ActiveSheet.Name Then
r = r + 1
Cells(r, 1) = ws.Name
Cells(r, 2) = ws.Range("A1")
Cells(r, 3) = ws.Range("B2")
Cells(r, 4) = ws.Range("C3")
End If
Next ws
End Sub
No.2
- 回答日時:
こんな感じでどうですかね?
-----
All_Sheet_Count = Workbooks("対象ブック名").Sheets.Count
'***** シート情報取得&配置
For Active_Sheet_Count = 1 To All_Sheet_Count
Active_Sheet_Name = Workbooks("対象ブック名").Sheets(Active_Sheet_Count).Name
If Active_Sheet_Name <> "集計シート名" Then'***** 集計シート場合はスキップ
With Workbooks("対象ブック名").Worksheets(Active_Sheet_Name)
集計シートの書きたいセル位置 = Active_Sheet_Name '***** 数値1
集計シートの書きたいセル位置 = .Range("A1").Text '***** 数値1
集計シートの書きたいセル位置 = .Range("B2").Text '***** 数値2
集計シートの書きたいセル位置 = .Range("C3").Text '***** 数値3
End With
End If
Next Active_Sheet_Count
-----
シートの数を数えて、1~シート数まで単純ループ
その中で、値を取りながら集計シートに配置するだけ
※当然配置位置はカウントしながらズラして
集計シートが見つかった時だけスキップする位の考慮は必要
いつもお世話になります。
長期出張中だったため、お礼が遅くなりまして大変申し訳ございませんでした。
非常に分かりやすく説明していただきまして、私でも理解できました。ありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) vbaエクセルマクロ RemoveDuplicatesについて RemoveDuplicatesを使 3 2023/02/28 01:13
- Excel(エクセル) エクセルのマクロについて教えてください。 3 2023/02/07 14:47
- Excel(エクセル) エクセルのフッタやヘッダーについて 3 2023/02/04 09:45
- Visual Basic(VBA) 顧客ごとに違う点検案内を作成するマクロ 4 2022/09/16 05:34
- Excel(エクセル) 前の(左隣の)シートを連続参照するように、あとから変更したい 1 2023/02/22 00:51
- Excel(エクセル) エクセル VBA セルの結合 2 2022/09/07 11:48
- Excel(エクセル) エクセルの数式について教えて下さい。 8 2023/05/27 12:17
- Visual Basic(VBA) vbaエクセルマクロ RemoveDuplicatesについて RemoveDuplicatesを使 1 2023/02/27 22:21
- Excel(エクセル) シート参照を含む数式を連続コピー 3 2022/12/10 11:42
- Visual Basic(VBA) Excel VBA 最終行を取得しVlookup関数をコピーする方法をコーディングで教えてください。 3 2023/05/11 13:14
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
別のシートから値を取得するとき
-
VBAの天才来てください
-
【ExcelVBA】全シートのセルの...
-
ユーザーフォームに入力したデ...
-
VBA 存在しないシートを選...
-
エクセルのシート名変更で重複...
-
XL:BeforeDoubleClickが動かない
-
同じ作業を複数のシートに実行...
-
ExcelVBA シート名を複数セルか...
-
エクセルのマクロでアクティブ...
-
【VBA】指定した検索条件に一致...
-
excelのマクロで該当処理できな...
-
VBAでオブジェクト変数にsetし...
-
エクセル・マクロ シートの非...
-
ブック名、シート名を他のモジ...
-
Excelマクロのエラーを解決した...
-
VBA 検索して一致したセル...
-
Worksheet_Changeの内容を標準...
-
シートが保護されている状態で...
-
エクセルVBAでダブルクリックを...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
別のシートから値を取得するとき
-
ユーザーフォームに入力したデ...
-
Excelマクロのエラーを解決した...
-
excelのマクロで該当処理できな...
-
同じ作業を複数のシートに実行...
-
ExcelVBA シート名を複数セルか...
-
【ExcelVBA】全シートのセルの...
-
Excel マクロについての相談
-
VBA 存在しないシートを選...
-
実行時エラー'1004': WorkSheet...
-
特定の文字を含むシートだけマ...
-
ExcelのVBAのマクロで他のシー...
-
ブック名、シート名を他のモジ...
-
XL:BeforeDoubleClickが動かない
-
VBA 複数の各シートに行を追加...
-
エクセルのシート名変更で重複...
-
【Excel VBA】Worksheets().Act...
-
シートが保護されている状態で...
-
Excel VBA 複数行を数の分だけ...
-
for 文の 繰り返し処理に使える...
おすすめ情報