• ベストアンサー
※ ChatGPTを利用し、要約された質問です(原文:進捗管理表のある条件なかで最新日程を検索したい)

営業の進捗管理表で最新日程を検索する方法

このQ&Aのポイント
  • 営業の進捗管理表には、訪問日や面談結果などが記録されています。しかし、特定の条件で最新の日程を検索することは難しい場合があります。
  • Excelの関数を使えば、簡単に最新日程を検索することができます。ただし、条件によっては思った通りの結果が得られないこともあります。
  • 進捗管理表にはさまざまなデータが含まれているため、関数を使いこなす必要があります。効率的な検索方法を学ぶことで、よりスムーズな進捗管理が行えます。

質問者が選んだベストアンサー

  • ベストアンサー
  • bunjii
  • ベストアンサー率43% (3589/8249)
回答No.2

>ところが更に上司から、M2の表示は「面談」もしくは「TEL」のどちらかの最新日程で。と追加条件が入りました。 前回の数式に一部誤りがありましたので追加条件も含めて次の数式を提言します。 M2=IFERROR(INDEX(A2:I2,,SUMPRODUCT(MAX((B2:I2="面談")*COLUMN(B2:I2)+(B2:I2="TEL")*COLUMN(B2:I2)))-1),"") N2=IFERROR(INDEX(A2:I2,,SUMPRODUCT(MAX((A2:I2="面談")*COLUMN(A2:I2)+(A2:I2="TEL")*COLUMN(A2:I2)))),"") N2をO2へコピーし、M2からO2までを一括して下へ必要数コピーします。 IFERROR関数はExcel 2007以降のバージョンから追加されましたのでExcel 2003以前のバージョンでは使えません。 この数式でSUMPRODUCT関数を使う理由は配列数式を特別な操作をしないで扱うためです。 基本的にはINDEX関数に与える列番号をMAX関数で抽出しています。 MAX関数の括弧内の数式は"面談"または"TEL"と記載されたセルの列番号を羅列するための配列計算式になっています。 SUMPRODUCT関数を使わない場合は数式を確定するときにCtrlとShiftを押しながらEnterキーで確定します。 結果を数式バーで確認すると=を含めた計算式が大括弧で括られています。 {=MAX((B2:I2="面談")*COLUMN(B2:I2)+(B2:I2="TEL")*COLUMN(B2:I2))} → MAX({0,3,0,0,6,0,0,9,0}) → 9

nikotannn
質問者

お礼

bunjiiさん お礼が遅れてスミマセン。 頂いた式で見事に、希望通りの管理表が出来ました。 ありがとうございます。 上司も非常に気に入り、他の部署にまで自慢する有り様。 (そこの部署の管理表まで作ることになりそうです) エクセルは奥が深いですね。 もっと上達したいなぁ。

その他の回答 (2)

  • tom04
  • ベストアンサー率49% (2537/5117)
回答No.3

こんばんは! 横からお邪魔します。 >面談」もしくは「TEL」のどちらかの最新日程で・・・ 一例です。 ↓の画像で上側がSheet1で下側のSheet2に表示するとします。 尚、訪問日が何度あっても(何列あっても)対応できるようにしてみました。 ↓の画像でSheet2のB2セルに =IF(OR(COUNTIF(Sheet1!2:2,"面談"),COUNTIF(Sheet1!2:2,"TEL")),INDEX(Sheet1!2:2,,MAX(MAX(IF(Sheet1!2:2="面談",COLUMN(2:2))),MAX(IF(Sheet1!2:2="TEL",COLUMN(2:2))))+COLUMN(A1)-2),"") これは配列数式になりますので、Ctrl+Shift+Enterで確定! この画面からコピー&ペーストする場合は 上記数式をドラッグ&コピー → Sheet2のB2セルを選択 → 数式バー内に貼り付け → そのまま(編集可能なまま) Ctrl+Shiftキーを押しながらEnterキーで確定! 数式の前後に{ }マークが入り配列数式になります。 これを列・行方向にフィルハンドルでコピー! B列の表示形式は日付にしておきます。 ※ Sheet1が空白の場合、「0」が表示されてしまいますので、 Sheet2をアクティブにし → メニュー → ファイル → オプション → 詳細設定 → 次のシートで作業するときの表示設定 → 「ゼロ値のセルにゼロを表示する」のチェックを外しておきます。 これで画像のような感じになります。m(_ _)m

nikotannn
質問者

お礼

tom04さん ありがとうございます。お礼が遅れてスミマセン。 目的は同じでも、様々な関数で導くことができるのですね。 奥が深い・・・。 まだまだ瞬時で適切な関数を組めず、苦戦しています。 教えて頂き恐縮ですが、ベストアンサーは2度も回答を 頂いたbunjiiさんとさせて頂きました。 ご了承下さい。

  • bunjii
  • ベストアンサー率43% (3589/8249)
回答No.1

貼付画像はExcel 2013で検証した結果です。 L2=A2 M2=INDEX(A2:J2,,SUMPRODUCT(MAX((B2:J2="面談")*COLUMN(B2:J2)))-1) N2=INDEX(A2:J2,,SUMPRODUCT(MAX((B2:J2="面談")*COLUMN(B2:J2)))+1) M2セルの書式で数値の表示形式を日付に設定します。 L2からN2まで選択して下へ必要数だけコピーします。 尚、C社の6/6で面談者が空欄なので抽出結果に0が表示されてしまいます。これを避けるため仮に?を入力してあります。

nikotannn
質問者

お礼

ありがとうございます! 本当に嬉しいです。 早速やってみます。 また報告させていただきます。

nikotannn
質問者

補足

頂いた式で大枠は理解できたつもりでした。 ところが更に上司から、M2の表示は「面談」もしくは「TEL」のどちらかの 最新日程で。と追加条件が入りました。 MAXやSUMPRODUCTのもしくはでネット検索等し、色々と試してみましたが、 数式エラーとなってしまいます。 お手数ですが、再度ご教授頂けると幸いです。

関連するQ&A