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

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

ただいまの
回答率

90.47%

  • Excel

    1595questions

    Excelは、マイクロソフト社が開発しているデータ集計や分析を行う表計算ソフトの一つです。文書作成や表計算、資料作成などの多彩な機能を備えており、統合パッケージであるMicrosoft Officeに含まれています。

表にて行の検索を行い、該当する行番号の行から検索したい値を検索して存在しているか確認を行いたい

受付中

回答 3

投稿

  • 評価
  • クリップ 0
  • VIEW 289

turu_hoyu

score 2

前提・実現したいこと

以下のような表から2群の行の中にサバが存在するかどうか確認を行うためのシステムを作成しています。

群2,アユ,サバ,ヒラメ
群1,マグロ,サケ,イワシ
群3,タイ,ウナギ,サバ

発生している問題・エラーメッセージ

2群の行番号取得ができたのですが、
取得した行番号を使用して、HLOOKUP関数で検索をかけられるかと考えたのですが、2群の範囲をどのように記載したら良いかわかりません。
範囲をどのように書いたら良いかご教授いただけないでしょうか。

関数を使いはじめて間も無く、考え方が全く違っているとも思います。
どうぞよろしくお願いいたします。

試したこと

COLUMN(群2)
HLOOKUP(サバ,群2の行範囲,1,FALSE)

※群2の行範囲をどのように書いたらいいかわかりません。

補足情報(言語/FW/ツール等のバージョンなど)

Excel2013を使用しています。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • sazi

    2017/09/14 17:27

    COLUMN()は列番号を求めるものなので、どのように2群の行番号を取得しているのでしょう?

    キャンセル

  • kikukiku

    2017/09/14 17:43

    「群2,アユ,サバ,ヒラメ」は、例えばセルA1にカンマ区切りデータが入っているイメージですか?それとも、例えばセルA1に「アユ」、セルB1に「サバ」、セルC1に「ヒラメ」が入っているイメージですか?

    キャンセル

  • turu_hoyu

    2017/09/14 21:45 編集

    >saziさん たしかに列番号求めるものでした。間違った事を行っておりました。 行番号取得はrow()にて行おうと考えております。

    キャンセル

  • turu_hoyu

    2017/09/14 21:47

    >kikukikuさん 「セルA1に「アユ」、セルB1に「サバ」、セルC1に「ヒラメ」が入っているイメージ」こちらのイメージとなります。

    キャンセル

回答 3

0

最終的にどのようにしたいのかまだわかっていないのですが、
想像して回答します。
※たぶん違っていると思うのですが。。。

セルE1に下記の式を入れて、セルE2、セルE3にコピーするれば下表のようになります。

セルE1の式
=IF(ISERROR((HLOOKUP("サバ",B1:D1,1,FALSE))),"存在しない","存在する")

A B C D E
1 群2 アユ サバ ヒラメ 存在する
2 群1 マグロ サケ イワシ 存在しない
3 群3 タイ ウナギ サバ 存在する

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

0

kikukikuさんの関数で方向性はあっていると思うのですが、
質問者の "群2" の行で "サバ" が含まれる行の抽出という要件通りになっていないように
見受けられますので、上記要件を満たす関数を記載します。

E2セルに下記関数を記載し、他行にコピーしてみてください。

=IF($B2="群2",IF(COUNTIF($C2:$E2,"サバ"),"存在する","存在しない"),"存在しない")
※kikukiku様からの指摘により関数を修正しました。(2017/09/15 16:53)

こんな感じにE行が埋められると思います。

項番 A B C D E
1 群2 アユ サバ ヒラメ 存在する
2 群1 マグロ サケ イワシ 存在しない
3 群3 タイ ウナギ サバ 存在しない

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/09/15 16:27

    群2にサバが存在しなかった場合、#N/Aになると思いますので、エラー処理が必要かと思います。

    キャンセル

  • 2017/09/15 16:52

    kikukikuさん

    大変失礼致しました。エラー処理を失念していました。

    HLOOKUPを使用するとエラーハンドリングで複雑になりますので、COUNTIFを使用した関数に変更致しました。
    こちらで正常に動くと思います。

    =IF($B2="群2",IF(COUNTIF($C2:$E2,"サバ"),"存在する","存在しない"),"存在しない")

    キャンセル

0

質問の内容をあまり理解できていないかもしれませんが、こんな感じでしょうか?
イメージ説明

それぞれ、1行目の範囲に「群1」という名前を定義して、
2行目の範囲に「群2」という名前、3行目の範囲に「群3」の名前を定義します。

C6のセルに検索したい文字列を入力するようにします。
C7のセルに検索した群名(群1,群2,群3)を入力するようにします。

そして、C9に、下の計算式を入力します。
=IF(ISERROR(MATCH(C6,INDIRECT(C7),0)),"該当なし",INDEX(INDIRECT(C7),MATCH(C6,INDIRECT(C7),0)))

INDIRECT関数で検索したい領域を指定しています。
MATCH関数で、配列の位置番号を取得しています。
INDEX関数で、配列の位置番号から、値を取得しています。
関数の入れ子で、結果を表示させています。エラーの場合は、該当なしと表示させています。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

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

  • ただいまの回答率 90.47%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

  • 解決済

    excelのLookup関数の使い方について。

    Lookup関数で1つのセル(仮にA1のセルだとします)に「午前中」の文字が入ったら、他のセル(ここではB1だとします)は「0812」とセルを置き換えをしたいです。 その場合

  • 解決済

    VBA A,B,C…列方向へ検索値を移動したい

    お世話になっております。 下記、コードについて教えてください。 Sub 水平変位データ() Dim kensakuA As Range '検索する値 Dim

  • 受付中

    PHPでVLOOKUPの関数を作りたい

    phpのプログラムについてですが・・・ エクセルのVLOOKUP関数みたいな関数をphpで作れますか? csv形式で、下記のようなデータが入っており、配列として出力したいの

  • 解決済

    VLOOKUPの近似一致について

    VLOOKUPの近似一致について質問させてください。 下記図のとおり、数値を昇順に並べた検索対象列に対して、 109でVLOOKUPによる近似一致検索を行いました。 期待

同じタグがついた質問を見る

  • Excel

    1595questions

    Excelは、マイクロソフト社が開発しているデータ集計や分析を行う表計算ソフトの一つです。文書作成や表計算、資料作成などの多彩な機能を備えており、統合パッケージであるMicrosoft Officeに含まれています。

  • トップ
  • Excelに関する質問
  • 表にて行の検索を行い、該当する行番号の行から検索したい値を検索して存在しているか確認を行いたい