
No.1ベストアンサー
- 回答日時:
for each nextの制御には、取り出せるポインタの値はありません。
敢えて言えばfor eachしている変数自体がポインタです。ごく単純な1次元配列なら計算すれば求まりますが、2次元以上ではそれもできません。
たとえば:
sub macro1()
dim a, h
a = array(1,2,"a","b","c")
for each h in a
msgbox h & "," & application.match(h, a, 0)
next
end sub
#もっともこれでは、ループごとにカウンタを+1していくのと変わらないんですけどね。
どーしてもアドレス的な数字が必要なのでしたら、for each next制御はあきらめて、各次元のUboundまでfor to nextでぐるぐる数字を回してください。若しくは、前述したようにカウンタを用意してループした回数を数えて下さい。
お礼を入れ忘れていました、長い間の放置申し訳ありません。
ご助言に従って通常のfor文で処理したことで解決しました
「当然あるものだ」と思っていたせいで探すのに時間をかけてしまい、作業に使える時間が減ってこの時は大変でした
有難うございました
No.3
- 回答日時:
あ、すみません、#2です。
Sub testの
' もしくは Dim matrix()
これ↑は消し忘れなので無視してください。
Dim matrix()では動かない書き方だけのせたので。
No.2
- 回答日時:
こんにちは、お邪魔します。
(配列というのが配列変数のことなのだとして)(非オブジェクトの要素)
ここら辺の書き振りについてはは、ある程度個性に委ねられる部分があってもいいとは思いますが。
基本的に配列変数はFor Nextでインクリメントしながら回すのが一般的ですし扱い易いです。
私個人の決め事としては
配列変数をFor Each Nextで回してもいいとする条件としては
1)配列の要素を上書きする必要がないこと(言わずもがな、ですけど)
2)Variant型の要素(内部型式オブジェクト型以外なら何でも)が収められた
Variant型変数(もしくはVariant()型配列変数)
3)一次元、もしくは、二次元配列
4)二次元の場合は、単行、もしくは、単列、であること
5)ループ目的以外でUBoundを取得する必要がないこと
という風に決めています。
特に4)5)の条件が揃った時ぐらいですね、For Each Nextで回すメリットがあると思えるのは。
例としては
Sub test()
Dim matrix ' もしくは Dim matrix()
Dim v
Dim ret As String
Dim i As Long
If TypeName(Selection) = "Range" Then matrix = Selection.Columns(1).Value
i = 0 ' 省略可
If IsArray(matrix) Then
For Each v In matrix
i = i + 1
ret = ret & vbLf & CStr(i) & v
Next v
ret = Mid(ret, 2)
Else
ret = "1" & matrix
End If
MsgBox ret
End Sub
(1オリジン(LBound=1)の場合を例に挙げましたが
0オリジンならi = i + 1の位置を後ろにずらしたりして対応します。)
勿論、For Nextでも良いわけですし、むしろFor Each Nextで配列を回すのは
極限られた少数派だと思います。
ポインタに使えるのはVariant型だけですから、
仮にInteger配列をFor each Nextで回すのは、
例えば、スイカ一個をわざわざトラックの荷台に積む、ぐらいに違和感があるし
コストはかかるけどメリットなく、却って面倒が増えそうですよね。
そういう意味でも用途は限定されると思います。
コレクションオブジェクトやコレクションをループする場合は
堂々とFor Each Nextでまわして良いと思いますが
非オブジェクトの値を要素に持つ配列の場合は素直に
For Nextで回すのが優先ってことだけは頭に入れといてください。
失礼しました。
> コレクションオブジェクトやコレクションをループする場合は
> 堂々とFor Each Nextでまわして良いと思いますが
> 非オブジェクトの値を要素に持つ配列の場合は素直に
> For Nextで回すのが優先ってことだけは頭に入れといてください。
お礼が遅れて申し訳ありません
独学でやっていたため基礎的なことが欠けている部分があるのですが、これもその一端でしょうか…
この時以降気をつけるようにしています
ありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
エクセルのラベルの値(文字列)を垂直方向で中央揃えにするには?
Excel(エクセル)
-
動的配列が存在(要素が有る)か否かを判定できますか?
Visual Basic(VBA)
-
VBAで保存しないで閉じると空のBookが残る
Excel(エクセル)
-
-
4
worksheetFunctionクラスのVlookupプロパティを取得できません エラーへの対応
Visual Basic(VBA)
-
5
VBAでエクセルシートを更新(リフレッシュ)する方法を教えて下さい。
Excel(エクセル)
-
6
VBAでユーザーフォームを再表示させたい。
Excel(エクセル)
-
7
VBAのコマンドボタンの文字列の改行方法は?
Visual Basic(VBA)
-
8
メッセージボックスのOKボタンをVBAでクリックさせたい
Visual Basic(VBA)
-
9
IF関数で空欄(")の時、Nullにしたい
その他(Microsoft Office)
-
10
ExcelVBA EnableプロパティがFalseの時に文字の色を変えたくない
Visual Basic(VBA)
-
11
「Columns(A:C")」の列文字を数字にして表記したい"
Excel(エクセル)
-
12
CloseとDisposeの違い
Visual Basic(VBA)
-
13
Application.ScreenUpdating = Falseが効きません
Visual Basic(VBA)
-
14
エクセルVBAでUserFormを起動した時
Excel(エクセル)
-
15
Visual Studio 「AnyCpu」について
C言語・C++・C#
-
16
VBAで配列の計算
Excel(エクセル)
-
17
VBA 1次元配列を2次元に追加する
Visual Basic(VBA)
-
18
Application.Runエラー(1004)
Excel(エクセル)
-
19
VBAでワークシートを引数としてサンプル関数に渡したい
Visual Basic(VBA)
-
20
VBA バックグラウンドで別ブックを開いてデータ転記
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
配列数式の解除
-
VBA 1次元配列を2次元に追加する
-
エクセルで最小値から0を除く方法
-
モンテカルロ法を用いた積分計...
-
2つ以上の変数を比較して最大数...
-
2次元動的配列の第一引数のみを...
-
Excel-VBAで内臓のMINVERSE,MM...
-
VBAで近似曲線の係数取得
-
MATLABにて場合分け関数を定義...
-
for each の現在の配列ポインタ...
-
Array配列の末尾に追加したい。
-
ListViewで、非表示列って作れ...
-
Dim は何の略ですか?
-
特定のセル範囲で4文字以上入力...
-
VB6 配列を初期化したい
-
配列変数の添字が範囲外ですと...
-
C++のテーブル検索に関する質問...
-
教えて下さい
-
特定のPCだけ動作しないVBAマク...
-
エクセルで特定の列が0表示の場...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
配列数式の解除
-
2つ以上の変数を比較して最大数...
-
特定のセル範囲で4文字以上入力...
-
VBA 1次元配列を2次元に追加する
-
subの配列引数をoptionalで使う...
-
配列変数の添字が範囲外ですと...
-
2次元動的配列の第一引数のみを...
-
ListViewで、非表示列って作れ...
-
MATLABにて場合分け関数を定義...
-
VB6 配列を初期化したい
-
AES暗号にて、AES_set_encrypt_...
-
配列を任意の数値で埋める方法
-
RPG E仕様書について
-
VBのFunctionで、配列を引数...
-
ビンゴ
-
エクセルで最小値から0を除く方法
-
順列の作成
-
VBA Match関数の限界
-
VLOOKUP関数で、一番下...
-
for each の現在の配列ポインタ...
おすすめ情報