C4=LOOKUP(0,0/FIND(B4,テーブル1[アドレス]),テーブル1[名称])
「テーブル1」の「アドレス」列を部分一致で検索し、「B4」セルの文字列に該当する項目があったら、「テーブル1」の「名称」列のデータを「C4」セルに表示するよう、インターネット上の情報を参照しながら数式を組んでいます。
ところが、「B4」セルの文字列に該当する項目があるときはいいのですが、該当項目がない場合は「#N/A」と表示されるため、「IF」関数を追加し、以下のようにしたところ、うまく動きませんでした。
C4=IF(COUNT(FIND(B4,テーブル1[アドレス])),LOOKUP(0,0/FIND(B4,テーブル1[アドレス]),テーブル1[名称]),"未使用")
「数式の検証」で調べたところ、「LOOKUP」関数内の「FIND」関数は「テーブル1」の「アドレス」列の各セルをそれぞれ参照しているのに対して、「COUNT」関数内の「FIND」関数は同じ行(C4の場合は4)の「テーブル1」の「アドレス」列しか参照していませんでした。
「LOOKUP」関数内の「FIND」関数のテーブル1[アドレス]: {"アドレス1";"アドレス2";"アドレス3"}
「COUNT」関数内の「FIND」関数のテーブル1[アドレス]: "アドレス4"
参照内容が異なるのはなぜでしょうか。
この場合、どのようにすればよろしいのでしょうか。
また、「LOOKUP」関数は「旧バージョンとの互換性を維持するためのもの」となっており、代わりに「VLOOKUP」や「HLOOKUP」、「MATCH」関数などで代用はできないのでしょうか。
何卒ご教示よろしくお願いいたします。
No.2
- 回答日時:
ご利用のエクセルのバージョンがご相談に書かれていませんが,情報から2010以降を利用しているのが明らかです。
とりあえずご質問の数式をそのまま活かしたいなら
=IFERROR(LOOKUP(0,0/FIND(B4,テーブル1[アドレス]),テーブル1[名称]),"未使用")
とでもしてください。
普段使いの関数を使い
アドレス列(仮にG列)のひとつ右隣(仮にH列)に名称列があるなら
=IFERROR(VLOOKUP(B4,G:H,2,FALSE),"未使用")
としたほうが,遙かに簡単です。
リストの配置をどうしても動かしたくないなら
仮にH列を検索してG列を取得する
=IFERROR(INDEX(G:G,MATCH(B4,H:H,0)),"未使用")
です。
ご回答ありがとうございます!
質問内容からOfficeのバージョンがお分かりになられるとは、流石です。
=IFERROR(LOOKUP(0,0/FIND(B4,テーブル1[アドレス]),テーブル1[名称]),"未使用")
としたほうが遥かにスマートですね!ぜひそのようにさせていただきます^_^
なぜLOOKUP(0,0/FIND(B4,テーブル1[アドレス]),テーブル1[名称])のような面倒な書き方になっているのかといいますと、部分一致でないと照合しないデータが含まれているからです。
ご教示の方法で「LOOKUP」関数を「VLOOKUP」や「INDEX」関数に置き換えてしまいますと、完全一致となり、一部のデータが誤って「未使用」となってしまいます。
No.1
- 回答日時:
複数一致するときに、どこの値が返ってくるか安定しないけどいいのかなあ
とか心配しつつ
FIND(B4,テーブル1[アドレス])
は、ヘルプに載っているような基本的な使用方法ではなく、配列として返しています。
そのままでは配列として認識していません。INDEX関数やLOOKUP関数など、配列を扱う関数なら、配列として扱われますが、COUNT関数は、セル範囲として扱う関数になっています。
で、配列として認識させるためには、
=IF(COUNT(FIND(B4,テーブル1[アドレス])),LOOKUP(0,0/FIND(B4,テーブル1[アドレス]),テーブル1[名称]),"未使用")
[Ctrl]+[Shft] +[Enter] で確定、配列数式。{ }で挟まれる。
または、配列として認識させるよう
=IF(COUNT(INDEX(FIND(B4,テーブル1[アドレス]),)),
LOOKUP(0,0/FIND(B4,テーブル1[アドレス]),テーブル1[名称]),"未使用")
といった方法もあります。
ご教示いただいた方法で無事に配列として認識させることができました。ありがとうございます!
「テーブル1[アドレス]」にはゴミデータが入っていて、部分一致でないと照合しませんが、重複することはないのでご心配なく^_^
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
あなたが普段思っている「これまだ誰も言ってなかったけど共感されるだろうな」というあるあるを教えてください
-
フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
あなたが普段思っている「これまだ誰も言ってなかったけど共感されるだろうな」というあるあるを教えてください
-
映画のエンドロール観る派?観ない派?
映画が終わった後、すぐに席を立って帰る方もちらほら見かけます。皆さんはエンドロールの最後まで観ていきますか?
-
海外旅行から帰ってきたら、まず何を食べる?
帰国して1番食べたくなるもの、食べたくなるだろうなと思うもの、皆さんはありますか?
-
天使と悪魔選手権
悪魔がこんなささやきをしていたら、天使のあなたはなんと言って止めますか?
-
Excelの関数LOOKUP(1,0/FIND(....))の意味
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
デザインビューで、連結式 を...
-
パススルークエリをテーブル作...
-
accessで指定期間の曜日カウン...
-
SQL: SELECT UNIONすると文字数...
-
Accessでテーブル名やクエリ名...
-
アクセスのメインフォームとサ...
-
Accessデータベースで測定デー...
-
アクセス2000のルックアッ...
-
Accessの追加クエリで既存のテ...
-
アクセスのテーブル間で同じ値...
-
ファイルメーカーのリレーショ...
-
Accessクエリでの、LIKE条件
-
アクセスのデータをエクセルに...
-
ACCESSで指定されたテーブルか...
-
Excel 2019 のピボットテーブル...
-
「直需」の意味を教えてください
-
必須入力項目と入力必須項目
-
ACCESSのクエリで集計で、先頭...
-
Access テキスト型に対する指定...
-
datファイルからaccessにインポ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Accessでテーブル名やクエリ名...
-
access テーブル内のレコード...
-
Accessレコードの追加や変更が...
-
Accessクエリでの、LIKE条件
-
Accessの追加クエリで既存のテ...
-
Accessでvlookupみたいなことは...
-
3つの表を1つに縦に連結する
-
ACCESSに同時アクセス(編集)を...
-
デザインビューで、連結式 を...
-
ACCESSで指定されたテーブルか...
-
Accessでテーブルからテーブル...
-
2つのテーブルを比較して一致し...
-
ツリー構造をRDBで表現するには?
-
SQLで条件指定結合をしたいがNU...
-
リンクテーブルを CopyObject ...
-
パススルークエリをテーブル作...
-
Accessでテーブルにパスワード...
-
SQL: SELECT UNIONすると文字数...
-
時間の足し算
-
INSERT時にデータ登録とmaxの発...
おすすめ情報