
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でエクセルシートを更新(リフレッシュ)する方法を教えて下さい。
Excel(エクセル)
-
-
4
worksheetFunctionクラスのVlookupプロパティを取得できません エラーへの対応
Visual Basic(VBA)
-
5
VBAでユーザーフォームを再表示させたい。
Excel(エクセル)
-
6
或るプロシージャの呼び出し元判定
その他(Microsoft Office)
-
7
Application.ScreenUpdating = Falseが効きません
Visual Basic(VBA)
-
8
VBAで保存しないで閉じると空のBookが残る
Excel(エクセル)
-
9
VBA 1次元配列を2次元に追加する
Visual Basic(VBA)
-
10
エクセルVBAでUserFormを起動した時
Excel(エクセル)
-
11
VBAでのユーザフォームの表示有無の確認について
Visual Basic(VBA)
-
12
Application.Runエラー(1004)
Excel(エクセル)
-
13
【マクロ】PasteSpecialメソッドにて、コードが動かない理由が分かりません
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
配列数式の解除
-
VBA 1次元配列を2次元に追加する
-
subの配列引数をoptionalで使う...
-
配列変数の添字が範囲外ですと...
-
特定のセル範囲で4文字以上入力...
-
delphiで配列を、コピーするには。
-
fortranでのcsvファイルの読み込み
-
Dim は何の略ですか?
-
VBAで近似曲線の係数取得
-
2次元動的配列の第一引数のみを...
-
フォートランの配列の受け渡し問題
-
【excel VBA】 配列番地の検索
-
特定のPCだけ動作しないVBAマク...
-
教えて下さい
-
UserForm1.Showでエラーになり...
-
【エクセル】測定時間がバラバ...
-
wordを起動した際に特定のペー...
-
一つのTeratermのマクロで複数...
-
String""から型'Double'への変...
-
【VBA】ワークブックを開く時に...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
配列数式の解除
-
特定のセル範囲で4文字以上入力...
-
ListViewで、非表示列って作れ...
-
2つ以上の変数を比較して最大数...
-
VBA 1次元配列を2次元に追加する
-
VBA Match関数の限界
-
配列変数の添字が範囲外ですと...
-
subの配列引数をoptionalで使う...
-
VB6 配列を初期化したい
-
【VBA】配列とWorksheetFunctio...
-
2次元動的配列の第一引数のみを...
-
エクセルVBAの配列二重ループ処...
-
VBAで近似曲線の係数取得
-
エクセルで最小値から0を除く方法
-
delphiで配列を、コピーするには。
-
Excel 2019 のヘルプの印刷
-
MATLABにて場合分け関数を定義...
-
個数が1以上の行を個数分行コ...
-
Dim は何の略ですか?
-
VBのFunctionで、配列を引数...
おすすめ情報