ExcelVBAで選択したシートのみのデータを1つのシートにまとめる

この記事では当方が実際に相談いただいた内容をまとめております。
選択したシートのみ1つのシートにまとめたいという方向けの記事です。

ExcelVBAで選択したシートのみのデータを1つのシートにまとめる方法

実際にご相談いただいた内容は下記になります。
「数値データ以外の文字列や日付を含むデータ件数1〜15行の仕入れスケジュール一覧が物品種類ごとに30シートほどあるのですが、これを1つの一覧表にまとめる方法」を教えて欲しい。
統合機能は試してみましたが、日付などが足し算されるのとアウトラインが邪魔で使いにくく(最終的に予定日付で昇順に並べ替えたい)断念しましたとのことでした。
「空白行を無視しつつ、30シート分のデータを常に一覧表示する方法はありませんか?」とご相談いただきました。
Excelの操作だと時間がかかってしまう、Excelの機能でやろうとしてみたけどできないという場合はExcelVBAで自動化すると時間短縮できます。

事前準備として下記のExcelファイルを用意しましょう。

Sheet1


Sheet2


Sheet3


Sheet4


AllData

選択したシートのみを統合して1つのシートにまとめるコードの作成


「開発」タブをクリック
「Visual Basic」をクリック
「ExcelVBAで選択したシートのみを統合して1つのシートにまとめるコード」の入力

選択したシートのみを統合して1つのシートにまとめるコードの解説

まずは選択したシートのみを統合して1つのシートにまとめる際にどんな処理を実装しないといけないかを紙に書き出してみましょう。
今回のコードの処理の流れは下記になります。

  • 選択されている集約用シートの2行目以降にデータが入っていれば2行目以降のデータを削除
  • 各シートの2行目以降のデータを集約用シートの末尾にコピーして値貼り付け
  • 空白行を削除する

※空白行を削除するコードについては別の記事で解説いたします。

選択したシートのみのデータを1つのシートにまとめるマクロをショートカットキーに割り当て

手順については「【ExcelVBA】特定のセルが見えるようにスクロールさせる」の記事の「マクロにショートカットキーの割り当て」を参照ください。

ショートカットキーで選択したシートのみのデータを1つのシートにまとめるマクロの実行

手順については「【ExcelVBA】特定のセルが見えるようにスクロールさせる」の記事の「ショートカットキーでマクロを実行する」を参照ください。

結論(まとめ)

「ExcelVBAで選択したシートのみのデータを1つのシートにまとめる方法」を解説しました。

  • 選択したシートのみのデータを1つのシートにまとめるコードの作成
  • 選択したシートのみのデータを1つのシートにまとめるマクロをショートカットキーに割り当て
  • ショートカットキーで選択したシートのみのデータを1つのシートにまとめるマクロの実行

Follow me!

The following two tabs change content below.
大阪生まれの大阪育ち。システム開発系、パソコン教室運営管理、パソコンサポートの仕事を中心に10年以上IT業界に生息しているけれども、実はHTMLやCSSが苦手。 パソコン教室やパソコンサポートなどでお客様から「ありがとうございます。」という感謝の言葉をいただいたときにやりがいを感じる。もっと自分のITのスキルで人様のお役に立ちたいと考え、義経ITクラブを開業して日々を送る。

中小企業デジタル化応援隊事業IT専門家森山義章のホンマル☆ラジLive♬(7月より配信予定)

この番組では

IT起業家・著者・ITインストラクター・WEB集客コンサルタント・システムエンジニア・プロデューサーとしてマルチに活躍し続ける、

書籍は出版後24時間以内でAmazon言語学の参考図書部門第1位獲得、

Amazon女性と仕事 (Kindleストア)部門第1位獲得のベストセラー著者、Podcast配信後わずか3日以内に教育ハウツー部門でランキング第1位獲得(日本)、

1ヶ月以内にたった7つのブログ記事でGoogle検索順位1位を獲得したWEB集客専門家、

出品後半年以内でココナラITサポートおすすめ順第1位獲得のITコンサルタント、

30歳を過ぎてADHD・高機能自閉症と診断されたITプロデューサー・森山義章が人間関係、健康、お金、仕事、ビジネスなど望む結果を出せる思考行動へと変えていきます。

コメントを残す

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です

CAPTCHA