top of page

​タグ一覧

配列処理(73)

階層化フォーム(33)

ファイル操作(28)

開発事例(22)

シート・セル操作(18)

図形操作(13)

コード自動生成(10)

ユーザーフォーム(9)

文字列操作(8)

設計思想(7)

開発効率化(6)

数学(6)

GAS(5)

アニメーション(5)

技術解説(4)

講座実施報告(5)

イミディエイトウィンドウ(4)

Googleスプレッドシート(4)

副業(4)

クリップボード(4)

条件付き書式(4)

その他(4)

ココナラ(3)

小説(3)

HTML(3)

JavaScript(3)

OneDrive(2)

イベントプロシージャ(2)

Enum(2)

PDF(2)

フリーランス(2)

リスキリング(2)

Outlook(2)

介護(2)

Discord(2)

シフト表(2)

LookerStudio(2)

日報(2)

カレンダー(2)

罫線(2)

パズル(2)

小ネタ(2)

コード解説(2)

クラスモジュール(2)

ステータスバー(1)

コード解析(1)

バックアップ(1)

可変長引数配列(1)

ブック処理(1)

スクレイピング(1)

スプレッドシート(1)

coconala(1)

リボン登録マクロ(1)

QRコード(1)

実行予約(1)

給与計算(1)

VBA不使用(1)

リボン(1)

超勉強会(1)

スピログラフ(1)

図名描写(1)

連想配列(1)

溶接ロボット(1)

保育士(1)

楽天市場(1)

経理(1)

医療(1)

文書作成(1)

発注書(1)

ショートカット(1)

WebAPI(1)

色操作(1)

スーパー開発ショートカット(1)

ライブラリ処理(1)

放課後等デイサービス(1)

児童福祉支援(1)

学校(1)

UI(1)

CAD(1)

カーソル操作(1)

二次元配列の特定列をキーとして、配列をユニーク値ごとに分割する汎用プロシージャ Excel VBA

二次元配列の特定列をキーとして、配列をユニーク値ごとに分割する汎用プロシージャ Excel VBA

<概要>

 本記事では、二次元配列の特定列をキーとして、配列をユニーク値ごとに分割する汎用プロシージャDivideArray2DCol_Unique を紹介します。


Excel VBA では、ワークシート上ではフィルターやピボットで簡単に行える処理でも、配列上で同等の処理を行おうとすると記述が煩雑になりがちです。


本プロシージャを使用すると、

  • 二次元配列の任意の列を指定するだけで

  • その列のユニーク値ごとに行を抽出し

  • 「一次元配列の各要素に、対応する二次元配列を格納」


という構造で結果を取得できます。

内部では、

  • 指定列の抽出

  • ユニーク値の取得

  • 条件指定による二次元配列のフィルタ処理


といった汎用プロシージャを組み合わせて処理しており、配列をデータベース的に扱うための基盤処理として利用できます。


カテゴリ別集計、グループ単位の処理、後続ロジックへの受け渡しなど、実務での再利用性が高い汎用プロシージャです。


<実行例>

 実行例のサンプルコードは次の通りです

 上記コードで配列の中身の確認には以前に紹介したDPAを利用しています。


 実行結果のイミディエイトウィンドウは次のようになります。


DivideArray2DCol_Uniqueの実行サンプルの実行結果

 このように、二列目の「果物」「野菜」「飲料」それぞれ別々でフィルター処理して抽出された二次元配列が1つ1つ一次元配列に格納されてるっていうのが確認できます。


<関連コード>

 今回の汎用プロシージャは、下記の別で紹介している汎用プロシージャを使用しています。


<関連記事>

 今回紹介しているような汎用プロシージャを部品として一元管理する方法は別記事で紹介していますので、是非このノウハウも参考にしてみてください。

 コーディングを効率化する上でどんどん増やしていった汎用プロシージャ(部品)をいくら増やしても簡単に流用ができるような仕組みの構築が可能になります。


<コード>


Excel VBAによる業務自動化・ツール開発をご検討の方へ

​"脱Excel"の前に、現状のExcelの潜在能力を120%発揮してみませんか?

Softex-Celware

​インボイス登録番号:T5810983887134

  • Facebook
  • Twitter
  • YouTube

©2023 softex-celware。Wix.com で作成されました。

bottom of page