top of page

​タグ一覧

配列処理(67)

階層化フォーム(33)

ファイル操作(23)

シート・セル操作(11)

コード自動生成(10)

ユーザーフォーム(8)

図形操作(7)

GAS(5)

アニメーション(5)

技術解説(4)

副業(4)

考え方(4)

条件付き書式(4)

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

Enum(3)

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

ココナラ(3)

クリップボード(3)

介護(3)

開発効率化(2)

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

PDF(2)

フリーランス(2)

リスキリング(2)

Excel(2)

Excel小ネタ(2)

数学(2)

Outlook(2)

文字列操作(2)

小説(2)

HTML(2)

JavaScript(2)

日報(2)

カレンダー(2)

パズル(2)

ステータスバー(1)

コード解析(1)

静的変数(1)

OneDrive(1)

バックアップ(1)

可変長引数配列(1)

ブック処理(1)

スクレイピング(1)

スプレッドシート(1)

coconala(1)

リボン登録マクロ(1)

QRコード(1)

実行予約(1)

給与計算(1)

VBA不使用(1)

リボン(1)

超勉強会(1)

六角形(1)

Excel遊び(1)

ボウリング(1)

時計(1)

スピログラフ(1)

図名描写(1)

連想配列(1)

イベント(1)

溶接ロボット(1)

VBA(1)

脱Excel(1)

Discord(1)

ECサイト(1)

CSV(1)

楽天(1)

保育士(1)

シフト表(1)

CDP(1)

楽天市場(1)

経理(1)

javascript(1)

医療(1)

文書作成(1)

LookerStudio(1)

シフト(1)

セキュリティ(1)

発注書(1)

ショートカット(1)

WebAPI(1)

色操作(1)

罫線(1)

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

ライブラリ処理(1)

開発事例(1)

二次元配列を基準セルを左上に一括出力する

<概要>

 今回は二次元配列を基準セルを左上として一括出力する汎用プロシージャの紹介です。


 二次元配列のセルへの一括出力は、配列の中身をセル上への出力を高速化するためになくてはならない技術です。

 基本構文は次のようになっています。

 ただ、このセル範囲において必要な情報となってくるのは、出力する基準の左上のセルだけで、出力するセル範囲は二次元配列の行数列数から自動的に決まってきます。

 このことを考慮した場合に、二次元配列の一括出力において必要な情報は「出力するに次元配列」「左上の基準セル」の2つになります。

 

 また部品として汎用プロシージャとして構築する場合は、出力するセル範囲に別々の情報を何度も出力するという風になった場合は、それぞれ出力する二次元配列の大きさよっては一つ前に出力した二次元配列の情報が一部残ったりする可能性があるので、事前に出力する範囲の初期化等の設定も必要になってきます。この初期化処理は紹介する汎用プロシージャーでの第三引数「Clear」で設定できるようになっています。


 ちなみに出力対象とする二次元配列は、必ず要素数は1が開始となるように限定しております。この理由として、もし1以外で0開始の二次元配列も対応しようとした場合に汎用プロシージャの中の行動が複雑化することと、現実的に0開始の二次元配列を扱うことは滅多にないってことを考慮しております。


<実行例>

 実行例のコードは次のようになっております。

 出力する二次元配列は行数列数が3x4の配列を例にしております。

 出力する基準セルはB3セルとしています。

ree

 実際に実行すると、次の画像のように二次元配列がセル上に出力されているのがわかります。

ree

 

 ちなみに、一般的なExcel VBAの教材では一つ一つのセルに一つの値を一つずつ入力するような教え方が多いですが、実務上ではそのようなやり方やると非常に処理が遅い実装になり、使用する側としてもストレスがたまりやすいものになってしまいます。私が教える場合はこのような処理は「ご飯の米粒を1つずつ食べるような行為」と揶揄しております。子育てを経験すると実感しやすい表現です。

 実務上でExcel VBを実装する場合は、できるだけ出力する内容を配列に一つに貯めてから一括で出力するようにすると、より処理の早いストレスの溜まりにくいツールが出来上がります。


<関連記事>

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

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


<コード>



コメント

5つ星のうち0と評価されています。
まだ評価がありません

評価を追加
Softex-Celware

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

  • Facebook
  • Twitter
  • YouTube

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

bottom of page