
こんばんわ。
VBAでVLOOKUPを実施していますが値が見つからない場合#N/Aが表示されてしまいます。
これを表示させない良い方法ありますでしょうか?
以下のようにCells(1,i)がブランクになるまで別シート(日別商品別集計)の40列目の値を検索するロジックです。処理はうまくいっていますが値がない場合は” ”にしたいのですが”#N/A”が表示されてしまいます。
Do While Cells(1, j) <> ""
ActiveCell.Value = Application.VLookup(Cells(1, j), Worksheets("日別商品別集 計").Range("A2:AN533"), 40, False)
*エラーの場合
On Error GoTo ERR_1
ERR_1:
ActiveCell.Value = ""
j = j + 1
ActiveCell.Offset(0, 1).Select
Loop
どなたかご教授いただけませんでしょうか?
よろしくお願い致します。
No.2ベストアンサー
- 回答日時:
一例です。
エラーは文字列判定ではなくIsErrorで行いますので、一旦、別の変数で受ける方が良いと思う。
result = Application.VLookup~
If IsError(result) Then
エラー処理
mu2011さん、早速のご連絡ありがとうございます!
ご教授いただきました方法でうまく動作しました!!
この度は本当にありがとうございました!
No.1
- 回答日時:
この処理では、別にVBAとしてはエラーしません。
ActiveCell.Value は正常に処理され #N/A という値が
入力されただけなので、OnErrorに飛ばないんです。
ですので、
IF ActiveCell.Value = #N/A THEN ActiveCell.Value = ""
みたいな処理が(動作チェックしてませんが)必要です。
この回答への補足
FEX2053さん、早速のご連絡ありがとうございました!
ご教授いただきました通り下記のようにしてみましたが”型が一致しません”というエラーがでてしまいます・・。このActivecellの書式は”標準”になっています。
If ActiveCell.Value = "#N/A" Then
ActiveCell.Value = ""
End If
何がいけないのでしょうか?
度々申し訳ございませんがアドバイスお願いいたします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
もしセルが#N/A"なら~をする・・・には?"
Excel(エクセル)
-
マクロで#N/A"のエラー行を削除したい"
Visual Basic(VBA)
-
エクセルVBAで#N/Aのようなエラー値を含むセルの検出は
Visual Basic(VBA)
-
-
4
エクセル:マクロ「Application.CutCopyMode = False」って?
Excel(エクセル)
-
5
#N/Aの文字を削除するには
Visual Basic(VBA)
-
6
vba 2つの条件が一致したらコピーして別シートに値のみ貼り付け
Visual Basic(VBA)
-
7
VBAで保存しないで閉じると空のBookが残る
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
【C#/Java?】try-catchでcatch...
-
private subモジュールを他のモ...
-
シグナル 6(SIGABRT)とは?
-
Excel VBA セルの名前があるか...
-
IF文に時間(何時から何時ま...
-
マクロで、次のコードへ行く前...
-
VB6にてネットワーク上にある共...
-
Word VBA。各マクロの間に待ち...
-
VBA 複数の行を高速で削除する...
-
【VBA】エラー処理で別プロシー...
-
ListViewから選択中の文字列を取得
-
Vba 互換モードでのAppActiveに...
-
ExcelのVBAで、選択したファイ...
-
入力した値が不正というよりイ...
-
途中で処理を中断させたい (ア...
-
複数のファイルに対し同じ処理...
-
シェルスクリプトでファイル内...
-
n88 Basic に関して(ループ)
-
条件文でelseはつけるべき?
-
バッチファイルでのエラー処理...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
【C#/Java?】try-catchでcatch...
-
private subモジュールを他のモ...
-
vbaのエラー対応(実行時エラー...
-
シグナル 6(SIGABRT)とは?
-
IF文に時間(何時から何時ま...
-
マクロで、次のコードへ行く前...
-
Excel VBA セルの名前があるか...
-
どう増強すべきか
-
特定の名前のオートシェイプの...
-
途中で処理を中断させたい (ア...
-
特定のファイルを他のプロセス...
-
順番に処理させたい
-
Word VBA。各マクロの間に待ち...
-
StatusStripの表示が更新されな...
-
ドリブン??
-
ExcelのVBAで、選択したファイ...
-
RaiseEventのメリット
-
【VBA】エラー処理で別プロシー...
-
エクセルVBAでロックをかけたい
-
どうやってもFor文を抜けてしま...
おすすめ情報