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)

開始要素番号が1となるArray関数(Excel VBA)

<概要>

 今回は1開始の一次元配列を作成する汎用プロシージャ「ArrayStart1」の紹介です。


 通常、VBAのArray関数を使用して配列を作成すると、要素番号は必ず0から始まります。この仕様はVBAの標準挙動ですが、配列の開始番号を1に統一したい場合があります。特に次のような理由から、1開始の配列が有用です。


  1. Excel行番号との対応が容易: 配列の要素番号とExcelの行番号を対応させる場合、1開始で統一すると直感的に管理できます。

  2. 可読性と一貫性の向上: 他の配列処理と同じ番号基準で統一することで、コードの読みやすさが向上します。

  3. エラー防止: 0開始と1開始の混在による計算ミスやロジックエラーを防ぎます。


詳細な背景や配列管理の統一についての考察は、こちらの記事をご参照ください。

ree

 さらに、このプロシージャでは可変長引数を使用しており、複数の引数を柔軟に受け取る設計が可能です。それでは具体的な使用例を見ていきましょう。


<実行例>

ビフォー: 汎用プロシージャを使用しない場合


アフター: 汎用プロシージャ「ArrayStart1」を使用する場合


解説

ビフォーの場合の課題

  • Array関数は常に0開始の要素番号となる。

  • 配列の開始番号を1に統一して管理したい場合、手動で変換が必要。

  • 人間が直感的に理解しやすい1開始の番号に揃えたいが、標準関数では対応していない。


アフターの場合の利点

  • 「ArrayStart1」を使用することで、簡単に1開始の一次元配列を作成可能。

  • 可変長引数を活用し、複数の値を柔軟に受け取れる。

  • コードが簡潔になり、配列操作の管理が容易に。


<関連記事>

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

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

<コード>


コメント

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

評価を追加
Softex-Celware

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

  • Facebook
  • Twitter
  • YouTube

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

bottom of page