ExcelマクロVBA技術解説
文字列でのセル参照と文字列の計算式について(Evaluate,INDIRECT)

ExcelマクロVBAの問題点と解決策、エクセルVBAの技術的解説
最終更新日:2013-09-05

文字列でのセル参照と文字列の計算式について(Evaluate,INDIRECT)


セルまたはセル範囲を表す文字列からセル参照する場合と、文字列としての計算式から計算する場合です。



"Sheet1"
A1に、"Sheet2"
B1に、"A1"

"Sheet2"
A1に、"(2+3)*2"

このように入っている場合に、
"Sheet1"のC1に、"Sheet2"のA1の内容つまり"(2+3)*2"を表示する場合です。

まず最初に思い浮かぶのが、
ワークシート関数のINDIRECT関数です。

C1に、"=INDIRECT(A1&"!"&B1)"

このようにする事になります。

では、マクロVBAではどうするかですが、

まず、WorksheetFunctionには、INDIRECTはありません。

INDIRECT関数と、ほぼ同様機能として、

Application.Evaluateメソッド(Application.は省略可能)があります。

Application.Evaluate(Name)

使用する名前を、オブジェクトまたは値に変換します。

Name : Excelの名前付け規則に従って、対象オブジェクトの名前を指定します。

この説明はヘルプです、全く理解できない日本語です。(笑


つまり、この場合は、

Range("C1") = Evaluate(Range("A1") & "!" & Range("B1"))

これで、C1に、"(2+3)*2" と表示されます。

しかし、ちょっと待ってください。

Range("A1") & "!" & Range("B1")

これは、"SHeet2!A1"ということですよね。

これは、セル参照の文字列なのだから、

普通に、Rangeで良いはずです。

つまり、

Range("C1") = Range(Range("A1") & "!" & Range("B1"))

結果は同じになります。

これは至極当然ですし、通常はこのように書く事になります。



では、"SHeet2!A1" このセル値の、"(2+3)*2" この計算結果を取得したい場合にどうするか。

ワークシート関数なら・・・

出来ませんよね、そんな事・・・

いや、まあ、出来ないこともないのですが・・・

名前定義を作成します。
名前はなんでも良いので、仮に、"文字列計算"とします。
参照範囲に、"=EVALUATE(INDIRECT(Sheet1!$A$1&"!"&Sheet1!$B$1))"
Excelサンプル画像

これができたら、
C1セルに、"=文字列計算"
これで、答えの10がC3セルに表示されます。

このように出来ないこともないのですが、


ちょっとこれは、反則級の使い方ではないかと個人的には思います。

では、マクロVBAならどうするかですが、

Range("C1") = Evaluate(Range(Range("A1") & "!" & Range("B1")).Value)

これで、答えの10がC3セルに表示されます。

順に解説すると、

Range("A1") & "!" & Range("B1")"SHeet2!A1"

Range("SHeet2!A1")
"(2+3)*2"

Evaluate("(2+3)*2")10

となります。

まさに、このような文字列としての計算式を計算するには、他の代替え方法はありません。

Evaluateを使うしかないのです。

めったに必要に迫られることはないと思いますが、

他の方法が存在しない限り、知っておかなければならない必須メソッドになります。

多少余談なりますが、

Evaluateの省略形として、[]があります。

つまり、

[A1]

このような書き方も存在しますが、これはあくまで固定文字を引数にしている為、

応用範囲も限定されますし、かなり古い記述でもあり、使用しないほうが良いでしょう。

Evaluateは、文字列としての計算式を計算する場合だけの使用が望ましいです。




同じテーマ「マクロVBA技術解説」の記事

マクロ作成後に、表位置がずれた場合の対処
ExecuteExcel4Macroについて
再帰呼出しについて(再帰プロシージャー)
文字列でのセル参照と文字列の計算式について(Evaluate,INDIRECT)
リボンを非表示、2003以前ならメニューを非表示
印刷ページ設定の余白をセンチで指定する(CentimetersToPoints)
文字列としてのプロシージャー名を起動する方法(Run,OnTime)
ドキュメントの作成者を取得(GetObject,BuiltinDocumentProperties)
画像サイズ(横x縦)の取得について
文字種(ひらがな、全半角カタカナ、半角英大文字等々)の判定
オブジェクトとプロパティの真実

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

Excelワークシート関数一覧(2010以降)|VBAリファレンス(4月22日)
クラスとCallByNameとポリモーフィズム(多態性)|VBA技術解説(4月6日)
VBAでのタイマー処理(SetTimer,OnTime)|VBA技術解説(4月3日)
クラスとイベントとマルチプロセス並列処理|VBA技術解説(4月2日)
エクセルの日付と時刻のまとめ|エクセル関数超技(3月6日)
Excelシートの複雑な計算式を解析するVBA|VBAサンプル集(2月18日)
VBAクラスの作り方:独自Rangeっぽいものを作ってみた|VBA技術解説(2月16日)
VBAクラスの作り方:列名のプロパティを自動作成する|VBA技術解説(2月14日)
VBAクラスの作り方:列名の入力支援と列移動対応|VBA技術解説(2月11日)
クラスを使って他ブックのイベントを補足する|VBA技術解説(2月6日)

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

1.ひらがな⇔カタカナの変換|エクセル基本操作
2.最終行の取得(End,Rows.Count)|VBA入門
3.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
4.Range以外の指定方法(Cells,Rows,Columns)|VBA入門
5.RangeとCellsの使い方|ExcelマクロVBA入門
6.変数とデータ型(Dim)|ExcelマクロVBA入門
7.マクロって何?VBAって何?|ExcelマクロVBA入門
8.繰り返し処理(For Next)|ExcelマクロVBA入門
9.とにかく書いて見よう(Sub,End Sub)|VBA入門
10.セルに文字を入れるとは(Range,Value)|VBA入門



  • >
  • >
  • >
  • 文字列でのセル参照と文字列の計算式について(Evaluate,INDIRECT)

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


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






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

    本文下部へ