エクセル雑感
配列のUBoundがLBoundがより小さいことはあり得るか

ExcelマクロVBAとエクセル関数についての私的雑感
最終更新日:2020-09-02

配列のUBoundがLBoundがより小さいことはあり得るか


ツイッターでVBAのお題として出したものです。


配列の下限が上限より大きくなるような配列は存在するかの問題です。
LBound(ary) > UBound(ary)
この条件を満たすような配列は存在するか?

問題を出したツイート

配列の下限と上限を調べるにはLBound関数とUBound関数を使います。
変数aryについて、
LBound(ary) > UBound(ary)
この条件を満たすような配列は存在するかについての問題です。
以下の文章で正しいものはどれか?
・そんな配列は存在しない
・存在するがVBAで意図的に作ることはできない
・存在するしVBAで簡単に作ることができる
・にゃんともいえない

VBA マクロ 配列 UBoundがLBoundがより小さい
https://twitter.com/yamaoka_ss/status/1300811819997491202



回答・解説のツイート

以下で一連の解説ツイートをしています。

VBA マクロ 配列 UBoundがLBoundがより小さい
https://twitter.com/yamaoka_ss/status/1301146057494024193

お決まりの結果になってしまいました(笑)
「にゃんともいえない」もうこれは正解とも言えるけど、、、

正解は「存在するしVBAで簡単に作ることができる」
LBound(ary) > UBound(ary)
このような配列は存在するし、VBAで簡単に作成できます。


変数が配列であるかを確認するには、IsArray関数を使います。
つまり実際のVBAで書くと、
If IsArray(ary) Then
  If LBound(ary) > UBound(ary) Then
    MsgBox "これだ"
  End If
End If
このような状態の配列です。


では、
LBound(ary) > UBound(ary)

これがどのような時に発生するかというと、
長さ0の空の配列の場合に起こります。
LBound = 0
UBound = -1
このようになっている状態です。
Stringの""と同じようなものだと考えれば良いでしょう。


配列の要素数は、
UBound(ary) - LBound(ary) + 1
例えば、
Dim ary(0 to 2)
2 - 0 + 1 = 3
3個の要素を持つ配列になります。
要素数0の空の配列は、
-1 + 0 + 1 = 0
0個の要素を持つ配列という事になります。


このような配列をVBAで作成するには、以下のような方法があります。
ary1 = Array()
※ary1は、VariantもしくはVariant配列でなければなりません。
ary2 = Split("")
※ary2は、VariantもしくはString配列でなければなりません。


ただし、このような配列を使いまわす(他へ代入する)ような場合は注意が必要です。
1年前のアプデで問題が発生したのは記憶に新しいところです。
説明は以上です。
https://twitter.com/yamaoka_ss/status/1162215395723399169
VBA マクロ 配列のUBoundがLBoundがより小さい




同じテーマ「エクセル雑感」の記事

100桁の正の整数値の足し算
「VBA Match関数の限界」についての誤解
VBAで数値を漢数字に変換する方法
囲碁で相手の石を囲んで取るアルゴリズム
VBAで「3Lと5Lのバケツで4Lの水を作る」を解く
言語依存の関数を使用できるFormulaLocal
配列のUBoundがLBoundがより小さいことはあり得るか
ショートカット(Ctrl+Shift+n)抜け番ばどれだ
コレクションの要素を削除する場合
入力規則で○△を入れる数を制限する方法
greeenはgreenに、greeeeeNをGReeeeNに変換


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

import文(パッケージ・モジュールのインポート)|Python入門(9月24日)
例外処理(try文)とexception一覧|Python入門(9月23日)
リスト内包表記|Python入門(9月22日)
Pythonの引数は参照渡しだが・・・|Python入門(9月21日)
lambda(ラムダ式、無名関数)と三項演算子|Python入門(9月20日)
関数内関数(関数のネスト)とスコープ|Python入門(9月18日)
関数の定義(def文)と引数|Python入門(9月18日)
組み込み関数一覧|Python入門(9月17日)
辞書(dict型)|Python入門(9月16日)
入力規則への貼り付けを禁止する|VBA技術解説(9月16日)


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

1.最終行の取得(End,Rows.Count)|VBA入門
2.RangeとCellsの使い方|VBA入門
3.変数宣言のDimとデータ型|VBA入門
4.マクロって何?VBAって何?|VBA入門
5.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
6.Range以外の指定方法(Cells,Rows,Columns)|VBA入門
7.繰り返し処理(For Next)|VBA入門
8.セルに文字を入れるとは(Range,Value)|VBA入門
9.とにかく書いてみよう(Sub,End Sub)|VBA入門
10.マクロはどこに書くの(VBEの起動)|VBA入門




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


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



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