質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

マクロ

定義された処理手続きに応じて、どのような一連の処理を行うのかを特定させるルールをマクロと呼びます。

Q&A

解決済

2回答

1390閲覧

ExcelマクロでのVLOOKUP

Tera-Tomi

総合スコア9

VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

マクロ

定義された処理手続きに応じて、どのような一連の処理を行うのかを特定させるルールをマクロと呼びます。

0グッド

0クリップ

投稿2020/06/05 07:47

編集2020/06/08 01:28

前提・実現したいこと

Excelマクロで、コードをキーにVLOOKUPでマスタから値を二次元配列に格納し、一括代入したいと考えています。

発生している問題

VLOOKUPでマスタから値が取得できていません。
下部に記載されているマクロの On Error GoTo 部分をコメントアウトしたところ、下記のエラーが出ます。
「WorksheetFunctionクラスのVLookupプロパティを取得できません。」

マクロを使わず、Excelシート上でセルにマクロのソースと同じになる(はず)のVLOOKUPの文を入力すると、正しく値が取得できます。
※マスタにコードの重複はありません。
下記がExcelに直接入力したVLOOKUP文

vb

1=VLOOKUP($A4,マスタ!S:BB,4,FALSE)

該当のソースコード

イメージ説明

vb

1 ' 転記するデータを配列に格納する 2 Dim varTbBody() As Variant 3 eRow = wsTB_A.Cells(Rows.Count, 1).End(xlUp).Row 4 ReDim varTbBody(eRow, 5) 5 j = 0 6 7 With wsTB_A 8 ' 勘定コードごとにマスタの値を格納する 9 For i = pcTbDataRow To eRow 10 For k = 0 To 4 11 varTbBody(j, k) = CStr(funGetNameFromMst(wsCommon_mst.Range("S:BB"), .Cells(i, 1), k)) 12 Next k 13 j = j + 1 14 Next i 15 ' 試算表に転記する 16 .Range(.Range("B4"), Cells(eRow, 6)) = varTbBody 17 End With

プロシージャ内で呼び出しているファンクション

vb

1Public Function funGetNameFromMst(ByRef rangeVlookup As Range, ByRef strKey As String, ByRef strKey2) 2 On Error GoTo funGetNameFromMst_err 3 4 Dim strReturn As String 5 6 strReturn = "" 7 ' 渡されるKey2によって取得する列を分岐 8 Select Case strKey2 9 Case 0 ' G/L勘定タイプ 10 strReturn = WorksheetFunction.VLookup(CStr(strKey), rangeVlookup, 4, False) 11 Case 1 ' 機能領域 12 strReturn = WorksheetFunction.VLookup(CStr(strKey), rangeVlookup, 6, False) 13 Case 2 ' 税カテゴリ 14 strReturn = WorksheetFunction.VLookup(CStr(strKey), rangeVlookup, 12, False) 15 Case 3 ' 統制勘定 16 strReturn = WorksheetFunction.VLookup(CStr(strKey), rangeVlookup, 14, False) 17 Case 4 ' 原価要素タイプ 18 strReturn = WorksheetFunction.VLookup(CStr(strKey), rangeVlookup, 18, False) 19 End Select 20 21 funGetNameFromMst = strReturn 22 Exit Function 23 24funGetNameFromMst_err: 25 funGetNameFromMst = "" 26End Function

詳しい方いたら、何がいけないのか教えていただきたいです。
よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Nash-BETA

2020/06/05 08:54

エラーは出てきますか?それとも白紙で出てきますか?
Tera-Tomi

2020/06/08 01:26

On Error GoTo 部分をコメントアウトしたところ、下記のエラーが出ます。 「WorksheetFunctionクラスのVLookupプロパティを取得できません。」
guest

回答2

0

マスタの値が表示形式上、文字列となっているだけで、文字列として保存できていなかった。
マクロでマスタの値をすべて文字列に変換して代入したところ、VLOOKUPで値を取得することができた。

投稿2020/06/08 01:53

Tera-Tomi

総合スコア9

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

ベストアンサー

VBAでVLOOKUP関数を用いて値を取得する方法ですが、一部問題があります。
それば、#N/Aの時、つまり、該当データが無い場合です。
VLOOKUP関数を利用する前に、検索する値が表にあることをチェックしないとダメです。

私の場合は、COUNTIF関数で件数を調べて、0でなければ、処理するようにします。
やってみてください。

投稿2020/06/06 00:45

kai_keitai

総合スコア344

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Tera-Tomi

2020/06/08 01:22

回答ありがとうございます。 COUNTIF関数で件数を調べてから処理するマクロを作成したところ、COUNTIFのVLOOKUPでは件数として数えられていました。しかし値を取得するVLOOKUPではエラーが出ます。 どうやら、マスタの値が表示形式は文字列になっているのですが、確定(?)されていなかったため、取得できなかったようです。F2を押してEnterを押し、「数値が文字列として保存されています」と表示されるようになったら、値を取得することができました。 マスタの値を一括で文字列としての保存を確定(?)させるにはどうしたらよいのでしょうか。。
Tera-Tomi

2020/06/08 01:50

マクロでCStrで変換してマスタの値をすべて文字列として保存できました。 COUNTIF関数でのチェックはそのまま使います。ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問