No.2ベストアンサー
- 回答日時:
変数名を取得した後、何をしたいのでしょうか?
こんな方法もあるかと思います。
Private Type typHensu
HensuValue As String
HensuName As String
End Type
Dim Hensu(5) As typHensu
For i = 0 to 5
Hensu(i).HensuName = "Hensu"
Next
と構造体を定義しておいて、HensuNameメンバに変数名を入れる方法です。変数名を取得したければ、
Hensu(1).HensuName
とすればOKです。
もしくは構造体でなくクラスを使えば、デフォルトプロパティを使ったり、クラス初期化時に変数名をクラス自身が設定したりできるので、便利かもしれません。
ただ、その変数名"Hensu"を取得したとしても、どのような利用価値があるのかが謎です。それが冒頭の疑問ですので、補足していただければもっと良い方法や別の方からの意見が聞けると思います。
この回答への補足
最初はgHensuしかたかったんですけど、1,2,3・・・と増えていって同じことを何度も書いていることに気づいたもので、それでまとめられないかなぁ。。と思いました。
Get_gHensu の パラメータの一つに変数名を与えたかったのです。
gHensu0() AS String
gHensu1() AS String
gHensu2() AS String
gHensu3() AS String
gHensu4() AS String
gHensu0()=Get_gHensu("gHensu0",para0,para1,para2,para3)
gHensu1()=Get_gHensu("gHensu1",para0,para1,para2,para3)
gHensu2()=Get_gHensu("gHensu2",para0,para1,para2,para3)
gHensu3()=Get_gHensu("gHensu3",para0,para1,para2,para3)
gHensu4()=Get_gHensu("gHensu4",para0,para1,para2,para3)
No.3
- 回答日時:
VBレベル(番地を細工させない)の言語で変数名を取得する必要はあるのでしょうか。
プログラマーは変数名でプログラムを書いています。当然そのスペル(テキスト)は判っているわけです。
実行中に、他の名前に変わるわけではない。
だからそれを知らせる、プロパテイやメソッドはないと思う。
インタプリタやコンパイラが(特に後者)当初のソースでの変数名等と実番地を対照的にテーブル等で持っているかどうか知りませんが、持っていればその参照を許しても良いようには思う。昔昔の他の言語で、エラーなど出たとき、変数名で指摘してくれるとありがたいと思ったものですが、当時は行き詰まったアドレスしか表示しませんでしたが、今では変数名を指摘してくれるのがあるように思うが、それもチェック段階だけのようなきがする。
No.1
- 回答日時:
変数名を特定するものはなにでしょう?
変数名を特定するものが変数名ならば無理です。
ただ、入力されている値が決まっていて一意(重複していない値)の場合は、その値が入っている配列変数を取得することは出来ます。
Dim Hensu(5) as String
Dim i as integer
Dim Pick as String
Pick="2" '欲しい値
for i=0 to 5
Hensu(i)=Str(i)
IF Pick=Hensu(i) then
Debug.print i '欲しい値と同じ値が入っている
end if '配列の数を表示します
next i
簡単なプログラムですが、こんな答えでよろしいでしょうか?
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) 稀に1円合いません? Sheet1から金額と個数を貼り付ける下記コードで、金額を切り上げるコードを何 3 2022/09/05 15:11
- Visual Basic(VBA) Excel VBA ファイル取得について フォルダの中に、ファイル名“会議“を含むファイルが1つまた 9 2022/10/12 01:18
- Visual Basic(VBA) 別シートのデータを参照して値を入れたい。 まとめデータシートのC列D列の値を商品一覧シートのコードが 7 2022/08/17 13:20
- Visual Basic(VBA) 集めたシートのシート名を変更したい。 下記のコードでサブフォルダにあるファイルのSheet3を集めて 6 2022/08/23 10:38
- Visual Basic(VBA) 貼り付けた値が消えていく 以下はソースファイルの2番目のシートのB6から最終行を取得 ターゲットファ 2 2023/07/27 12:23
- Visual Basic(VBA) シートをコピーする下記記述でダイアログを用いた記述がわかりません?( A = Dir(ThisWor 4 2022/08/22 12:26
- Visual Basic(VBA) 複数のcsvファイルをExcelに一括変換したい 2 2023/03/03 12:44
- Visual Basic(VBA) 【ご教示ください】VBAの記述方法がわかりません。 2 2022/08/12 21:28
- Excel(エクセル) Excelにて、フォルダ内のTextファイルをマクロで統合すると文字化けしてしまう時の解消コード 4 2023/01/01 07:32
- Visual Basic(VBA) VBAのユーザーフォームのテキストボックスに入力制限をしたい 6 2022/11/15 08:28
このQ&Aを見た人はこんなQ&Aも見ています
-
外出時に「待たせる妻」vs イライラする「待つ夫」は日本だけ?見習いたい海外事情
夫の家事参加に積極的なイメージのある海外でも、同様の事例はあるのか。結婚カウンセラーの佐竹悦子さんに伺ってみた。
-
VBA 変数名に変数を使用したい。
Visual Basic(VBA)
-
Excel-vba 文字列と変数を連結して更に変数として扱いたい
その他(プログラミング・Web制作)
-
VBAでループ内で使う変数名を可変にできないか。
Visual Basic(VBA)
-
-
4
文字列を変数名として扱う方法
Visual Basic(VBA)
-
5
エクセルのラベルの値(文字列)を垂直方向で中央揃えにするには?
Excel(エクセル)
-
6
EXCELで特定のセルに表示された項目をヘッダーやフッターに出力するには
Excel(エクセル)
-
7
ExcelのVBA。public変数の値が消える
Visual Basic(VBA)
-
8
Excel-VBA>コントロールをグレイアウトするには?
Excel(エクセル)
-
9
配列をループでたくさん宣言したいのですが、配列名や変数名を変数で宣言することはできませんか?
Visual Basic(VBA)
-
10
VBA public変数はどのようなことをしたら解放されますか?
Visual Basic(VBA)
-
11
エクセルでエラーが出て困っています。
Excel(エクセル)
-
12
EXCEL VBAで全選択範囲の解除
Excel(エクセル)
-
13
VBA:ユーザーフォームのマルチページに色を付けたい。
Word(ワード)
-
14
TextBoxコントロールを引数として渡すには?
その他(教育・科学・学問)
-
15
Boolean型配列中のTrueの有無を判定したい(VB2005)
Visual Basic(VBA)
-
16
VBA プロシージャの名前の取得
その他(Microsoft Office)
-
17
エクセルVBA 配列からセルに「関数式」を一気代入したい
Visual Basic(VBA)
-
18
array関数で格納した配列の型を変更する
Visual Basic(VBA)
-
19
フォントの大きさ
Visual Basic(VBA)
-
20
本当にPublicな変数(配列で)
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
テキストボックスのvalueとtext...
-
値を返さないコード パス
-
マクロで奇数と偶数の値を2か所...
-
VB.NETでコンボボックスの1行目...
-
VBで電卓のメモリー機能はどの...
-
ポインタのプログラムについて
-
最大・最小を求めるプログラム
-
ハッシュテーブル(連想配列)が...
-
VB初心者。小数点以下の表示で...
-
C#の質問です
-
PL/SQLでのTO_DATEの時間取得に...
-
Dateserialで データ抽出
-
textboxとLabelを動的に変更する
-
【ASP.NET】 DataTextFieldの値...
-
アセンブリ言語について教えて...
-
VBAのIF分で値を入れる場合
-
マクロ 特定のセル値のみクリ...
-
VBA(自然数)
-
setcookieで「path」に複数の値...
-
VB2008 iniファイルの指定セク...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
テキストボックスのvalueとtext...
-
ハッシュテーブル(連想配列)が...
-
マクロ 特定のセル値のみクリ...
-
VB.NETでコンボボックスの1行目...
-
変数名の取得
-
値を返さないコード パス
-
Powershellのparamについて
-
power BI クエリエディター 〇...
-
PysimpleGUIでデータベースを作る
-
DataTableに対するLINQについて
-
Excel VBAのリストボックスの値...
-
VB初心者。小数点以下の表示で...
-
Excel VBA 複数選択したリスト...
-
ダブルクリックをした順番に数...
-
PL/SQLでのTO_DATEの時間取得に...
-
[VB.net] DataGridViewのコンボ...
-
マクロで奇数と偶数の値を2か所...
-
ASPの変数の値をJAVA Script内...
-
vb6のVSFlexGridで選択行、列の...
-
シーケンサで最小値を保持する
おすすめ情報