ツイッター出題回答
配列の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がより小さい




同じテーマ「ツイッター出題回答 」の記事

囲碁で相手の石を囲んで取るアルゴリズム
VBAで「3Lと5Lのバケツで4Lの水を作る」を解く
言語依存の関数を使用できるFormulaLocal
配列のUBoundがLBoundがより小さいことはあり得るか
コレクションの要素を削除する場合
greeenはgreenに、greeeeeNをGReeeeNに変換
数値変数の値を別の変数を使わずに入れ替える
Rangeオブジェクトを受け取り"行数,列数"で埋める
数式の関数の使用回数、関数名を配列で返す
日付型と通貨型のValueとValue2について
小文字"abc"を大文字"ABC"に変換する方法


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

ByRef引数の型が一致しません。|ツイッター出題回答 (2023-09-22)
シートコピー後のアクティブシートは何か|ツイッター出題回答 (2023-09-19)
Excel関数の引数を省略した場合について|ツイッター出題回答 (2023-09-14)
セル個数を返すRange.CountLargeプロパティとは|VBA技術解説(2023-09-08)
記号を繰り返してグラフ作成(10単位で折り返す)|ツイッター出題回答 (2023-08-28)
シートを削除:不定数のシート名に対応|VBAサンプル集(2023-08-24)
ランクによりボイントを付ける(同順位はポイントを分割)|ツイッター出題回答 (2023-08-22)
OneDrive使用時のThisWorkbook.Pathの扱い方|VBA技術解説(2023-07-26)
列幅不足による###表示や指数表示を判定する|VBA技術解説(2023-07-12)
シートを削除:不定数のシート名に対応|VBAサンプル集(2023-07-04)


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

1.最終行の取得(End,Rows.Count)|VBA入門
2.RangeとCellsの使い方|VBA入門
3.繰り返し処理(For Next)|VBA入門
4.変数宣言のDimとデータ型|VBA入門
5.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
6.マクロとは?VBAとは?VBAでできること|VBA入門
7.ブックを閉じる・保存(Close,Save,SaveAs)|VBA入門
8.並べ替え(Sort)|VBA入門
9.Range以外の指定方法(Cells,Rows,Columns)|VBA入門
10.条件分岐(IF)|VBA入門




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

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



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