ツイッター出題回答
シート内の全テーブルを1つに統合

ExcelマクロVBAとエクセル関数についての私的雑感
公開日:2022-08-01 最終更新日:2022-08-01

シート内の全テーブルを1つに統合


ツイッターで出題した問題です。


シート内にある複数のテーブルを、1つのテーブルに結合して別シートに出力します。


出題ツイート

【VBA問題】
「Sheet1」のランダムな位置に複数のテーブルがあります。(添付1)
テーブルは全て同一形式(列数・ヘッダーが同じ)です。
「Sheet2」に1つのテーブルとして出力してください。(添付2)

Excel VBA問題 テーブル

Excel VBA問題 テーブル


Excel VBA問題 テーブル
https://twitter.com/yamaoka_ss/status/1553664644274745344


出題者としての解答

Sub sample()
  Dim ws1 As Worksheet: Set ws1 = Worksheets("Sheet1")
  Dim ws2 As Worksheet: Set ws2 = Worksheets("Sheet2")
  ws2.Cells.Clear
  
  Dim tbl As ListObject, rng As Range, r As Long
  r = 1
  For Each tbl In ws1.ListObjects
    If r = 1 Then
      Set rng = tbl.HeaderRowRange
      ws2.Cells(r, 1).Resize(, rng.Columns.Count).Value = rng.Value
      r = 2
    End If
    Set rng = tbl.DataBodyRange
    ws2.Cells(r, 1).Resize(rng.Rows.Count, rng.Columns.Count).Value = rng.Value
    r = r + rng.Rows.Count
  Next
  Set tbl = ws2.ListObjects.Add(xlSrcRange, ws2.Range("A1").CurrentRegion, , xlYes)
End Sub

ListObjectsでテーブルを取得して、
HeaderRowRangeでヘッダー、DataBodyRangeでデータを取得して統合します。

サイト内の参考ページ

第130回.テーブル操作の概要(ListObject)
テーブルをVBAで操作する場合に使用するオブジェクトの概要説明です、テーブルは、セルの範囲を表(テーブル)に変換することで、関連するデータの管理と分析を容易にできるようになるエクセルの機能で、以前はリストと呼ばれていました。テーブルを作成して書式設定することで、データを視覚的に分析しやすくできます。
第131回.テーブル操作のVBAコード(ListObject,DataBodyRange)
テーブル操作の具体的なVBAコードをパターン別に掲載します、テーブルの全体的な構成は ・テーブル全体 ・見出し行 ・データ範囲 ・集計列 ・集計行 VBAでは、これらのオブジェクトを使い各要素にアクセスします。テーブル全体のオブジェクトがListObjectで、シート内に複数テーブルが作成可能なので、
第142回.テーブル全件処理とデータ最終行(ListObject,DataBodyRange)
テーブルの全件処理と実際にデータが入っている最終行の取得について具体的なVBAを掲載します。注意点として、最新の365でテーブルが拡張されないパターンについても説明しておきます。テーブルの全体的な構成は ・テーブル全体 ・見出し行 ・データ範囲 ・集計列 ・集計行 VBAでは、これらのオブジェクトを使い各要素にアクセ…




同じテーマ「ツイッター出題回答 」の記事

数値変数の値を別の変数を使わずに入れ替える
Rangeオブジェクトを受け取り"行数,列数"で埋める
数式の関数の使用回数、関数名を配列で返す
日付型と通貨型のValueとValue2について
小文字"abc"を大文字"ABC"に変換する方法
オブジェクトのByRef、ByVal、Variant
「マクロの登録」で登録できないプロシージャーは?
ジャグ配列から順列を作成する
シート内の全テーブルを1つに統合
VBA穴埋め問題「On Error GoToの挙動」
数珠順列(配置に条件付き)を全て出力する


新着記事NEW ・・・新着記事一覧を見る

第5章:AI×VBAでつまづかない!トラブルシューティングとAIとの付き合い方 |生成AI活用研究(2025-05-20)
第4章:【事例で学ぶ】AIとVBAでExcel作業を劇的に効率化する! |生成AI活用研究(2025-05-20)
第3章:AIを「自分だけのVBA先生」にする!質問・相談の超実践テクニック|生成AI活用研究(2025-05-19)
第2章 VBAって怖くない!Excelを「言葉で動かす」(超入門)|生成AI活用研究(2025-05-18)
第1章:AIって一体何?あなたのExcel作業をどう変える?(AI超基本)|生成AI活用研究(2025-05-18)
AI時代のExcel革命:AI×VBAで“書かない自動化”超入門|生成AI活用研究(2025-05-17)
Geminiと100本ノック 23本目:シート構成の一致確認|生成AI活用研究(5月16日)
AIが問う出版の未来は淘汰か進化か:AIと書籍の共存の道とは|生成AI活用研究(2025-05-16)
Geminiと100本ノック 22本目:FizzBuzz発展問題|生成AI活用研究(5月15日)
すぐに使える!生成AI プロンプト作成 実践ガイド|生成AI活用研究(2025-05-15)


アクセスランキング ・・・ ランキング一覧を見る

1.最終行の取得(End,Rows.Count)|VBA入門
2.繰り返し処理(For Next)|VBA入門
3.変数宣言のDimとデータ型|VBA入門
4.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
5.ひらがな⇔カタカナの変換|エクセル基本操作
6.RangeとCellsの使い方|VBA入門
7.メッセージボックス(MsgBox関数)|VBA入門
8.セルのクリア(Clear,ClearContents)|VBA入門
9.FILTER関数(範囲をフィルター処理)|エクセル入門
10.条件分岐(Select Case)|VBA入門




このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。


記述には細心の注意をしたつもりですが、
間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
掲載のVBAコードは動作を保証するものではなく、あくまでVBA学習のサンプルとして掲載しています。
掲載のVBAコードは自己責任でご使用ください。万一データ破損等の損害が発生しても責任は負いません。



このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。
本文下部へ