
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も見ています
-
プロが教えるわが家の防犯対策術!
ホームセキュリティのプロが、家庭の防犯対策を真剣に考える 2組のご夫婦へ実際の防犯対策術をご紹介!どうすれば家と家族を守れるのかを教えます!
-
EXCEL VBAで全選択範囲の解除
Excel(エクセル)
-
VBAでループ内で使う変数名を可変にできないか。
Visual Basic(VBA)
-
array関数で格納した配列の型を変更する
Visual Basic(VBA)
-
-
4
配列の値を置換するにはどうすればいいでしょう?
Excel(エクセル)
-
5
エクセルVBA 配列からセルに「関数式」を一気代入したい
Visual Basic(VBA)
-
6
VBAで保存しないで閉じると空のBookが残る
Excel(エクセル)
-
7
DATE型変数を初期化する方法
Visual Basic(VBA)
-
8
エクセルで別ブックをバックグラウンドでオープンする方法
Excel(エクセル)
-
9
配列の参照渡しで型が一致しません。
Visual Basic(VBA)
-
10
VBAのコマンドボタンの文字列の改行方法は?
Visual Basic(VBA)
-
11
コマンドボタンを押すたびに大きくなってしまう
Excel(エクセル)
-
12
ExcelのVBA。public変数の値が消える
Visual Basic(VBA)
-
13
EXCEL VBAのユーザーフォームに引数を渡す方法について
Excel(エクセル)
-
14
コマンドプロンプト実行後に画面を閉じない方法
Visual Basic(VBA)
-
15
VBA コレクションに2次元配列を追加して取り出す方法
Visual Basic(VBA)
-
16
VBAでワークシートを引数としてサンプル関数に渡したい
Visual Basic(VBA)
-
17
構造体をコレクションに入れて扱いたいのですが…
コレクション
-
18
Accessでフィールド名を変数(文字列)で・・・
Access(アクセス)
-
19
Excel-VBA>コントロールをグレイアウトするには?
Excel(エクセル)
-
20
エクセルでエラーが出て困っています。
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
人気Q&Aランキング
-
4
MATLABにて場合分け関数を定義...
-
5
配列で飛び飛びの値を指定して...
-
6
ListViewで、非表示列って作れ...
-
7
do-while文でa〜zまでを表示さ...
-
8
VB2008: CSV を二次元配列に読...
-
9
特定のセル範囲で4文字以上入力...
-
10
モンテカルロ法を用いた積分計...
-
11
VBA Match関数の限界
-
12
2つ以上の変数を比較して最大数...
-
13
Excel VABについて 下記記述が...
-
14
Excel・Word リサーチ機能を無...
-
15
教えて下さい
-
16
特定のPCだけ動作しないVBAマク...
-
17
Excel マクロ VBA プロシー...
-
18
ExcelのVBA。public変数の値が...
-
19
matlabでの標高断面図の作成
-
20
UserForm1.Showでエラーになり...
おすすめ情報
公式facebook
公式twitter