
同じ品番で、マスタの番号が変わるデータが、毎日更新されているとします。
品番で最新日付のマスタがわかるように〇印をつけたいです。(画像参照)
配列関数で
{=IF(MAX(IF(B3=$B$3:$B$14,$C$3:$C$14))=C3,"〇","")}
で成功したような気がしますが、誤ってセルをクリックしたりする事もあり
配列以外で簡単な方法はありませんでしょうか?
どなたか詳しいかたアドバイスいただけると嬉しいです。
◆データはどんどん増えていきます。
◆日付はどんどん下にいくにつれて新しくなります。
◆並び替えはしたくありません
◆エクセルは2016ですがtextjoinなど使えないです。

No.1ベストアンサー
- 回答日時:
こんばんは
>配列以外で簡単な方法はありませんでしょうか?
確かに、配列数式はご指摘のような扱いにくさはありますよね。
数式を入れた列を誤って変換するようなことを防止したければ、「シートの保護」を利用する方法も考えられると思います。
ご質問の内容を通常の関数式で行うことを考えてみると・・
ご提示のセル位置が不明ですが、式の内容から「品番」とあるセルがB2セルであるものと仮定しました。
(ご提示の式を入力しているのがD3セルと解釈しました)
ご提示の式と同等で良ければ、
=IF(COUNTIFS(B:B,B3,C:C,">"&C3),"","〇")
をD3セルに入力すれば同様の結果になるものと思います。
※ 同じ品番で同じ日付の最新データが複数存在する場合、全部に〇が付きます。
ただし、ご提示の式だとあらかじめデータが入力されていない行までに式をフィルコピーしてしまうと、データのない行には〇が表示されてしまいます。
それを避けたい場合には、D3セルに
=IF(COUNTIFS(B:B,B3,C:C,">"&C3)+(C3=0),"","〇")
としておくことで、下方にあらかじめフィルコピーしておくことも可能になると思います。
※ 例示の式では配列計算の範囲を全行にしてありますので、計算負荷がかかります。
負荷を減らしたい場合には、指定セル範囲を、使用する可能性のある範囲に狭めておくことで減らすことができます。
ありがとうございます!!お二方とも親切に教えてくださりとても選べないので初めに回答くださって嬉しかったのでベストアンサーとさせて頂きます。
No.3
- 回答日時:
添付画像をご覧ください。
表はテーブルとして作成しています。各項目のセル位置が不明なのでfujillinさんの回答とセル位置を合わせています。
ただし、ご質問者の掲示された表と一箇所だけ異なる部分があります。
13行目に品番eのデータがありますが、この日付がご質問者の掲示されたものは2023/3/4ですが、こちらの表は2023/3/3としています。
E3にfujillinさんの回答の数式を記述してみました。
fujillinさんの回答において、
>同じ品番で同じ日付の最新データが複数存在する場合、全部に○が付きます。
という注釈がついていますが、11行目と13行目を同じ日付にしたため、確かに品番eについては11行目と13行目の両方に○が表示されます。
fujillinさんの回答と同じ結果となる別の数式
=REPT("○",SUMPRODUCT((B:B=B3)*(C:C>C3)+(C3=0))=0)
という数式をF3に記述しています。
こちらも、11行目と13行目の両方に○が表示されます。
C列の日付が上から順に登録されていくとして、同じ日付でも後から登録されたもの(つまり行番号の大きい方)を最新データとする方法もあります。G3セルに
=REPT("○",ROW()=LOOKUP(1,0/(B:B=B3),ROW(B:B)))
という数式を記述しています。こちらの数式は、同じ日付でも後から登録されたものにのみ「○」が表示されます。
但し、前述のとおり「日付が上から順に登録されていく」ことが前提であり、日付の逆転が発生する場合は正しい結果になりません。
その場合は、とても長い数式になってしまいますし、fujillinさんの回答でも指摘されていますが、
>配列計算の範囲を全行にしてありますので、計算負荷がかかります。
という問題もあるので、範囲を300行までにした数式をお示しすると、
=REPT("○",ROW()=AGGREGATE(14,6,ROW(A$3:A$300)*(B$3:B$300<>"")*(B$3:B$300=B3)*(C$3:C$300=LARGE((B$3:B$300=B3)*(C$3:C$300),1)),1))
という数式を記述することになります。

お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
Excelで同じ商品名で、かつ日付が古いものを抽出する方法
Excel(エクセル)
-
【EXCEL】条件に一致した最新の日付の売上を抽出
その他(Microsoft Office)
-
最新の日付をVLOOKUP
Word(ワード)
-
-
4
【EXCEL】条件に一致した最新データのみを抽出
その他(Microsoft Office)
-
5
エクセルで最新の日付に色をつける
Excel(エクセル)
-
6
エクセルで複数条件を満たす時、n番目に新しい日付を返す
Excel(エクセル)
-
7
EXCELで直近の日付を抽出する関数
Excel(エクセル)
-
8
excel 最新のデータ(行)を抽出する関数
Excel(エクセル)
-
9
EXCELで○ヶ月を○年○ヶ月に変換したい。
Excel(エクセル)
-
10
エクセル:マクロ「Application.CutCopyMode = False」って?
Excel(エクセル)
-
11
エクセルで最高値、最低値の日付を表示させたい
Excel(エクセル)
-
12
条件が一致するものの中で古い日付を抽出
Excel(エクセル)
-
13
マクロ オートフィルタの検索値を所定のセルから参照
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルのVBAで集計をしたい
-
vba テキストボックスとリフト...
-
【画像あり】【関数】指定した...
-
【マクロ】実行時エラー '424':...
-
他のシートの検索
-
【画像あり】オートフィルター...
-
Office2021のエクセルで米国株...
-
【マクロ】【配列】3つのシー...
-
エクセルに写真が貼れない(フ...
-
エクセルでフィルターした値を...
-
【マクロ】【相談】Excelブック...
-
【マクロ】数式を入力したい。...
-
【マクロ】元データと同じお客...
-
エクセルのライセンスが分かり...
-
エクセルシートの見出しの文字...
-
セルにぴったし写真を挿入
-
Excelに貼ったXのURLのリンク...
-
【関数】=EXACT(a1,b1) a1とb1...
-
【マクロ】excelファイルを開く...
-
【関数】3つのセルの中で最新...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
【マクロ】元データと同じお客...
-
エクセルの関数について
-
【画像あり】オートフィルター...
-
エクセルのVBAで集計をしたい
-
エクセルのリストについて
-
【マクロ】数式を入力したい。...
-
【マクロ】【相談】Excelブック...
-
Office2021のエクセルで米国株...
-
【マクロ】実行時エラー '424':...
-
他のシートの検索
-
エクセルの複雑なシフト表から...
-
【マクロ】【配列】3つのシー...
-
vba テキストボックスとリフト...
-
【マクロ】左のブックと右のブ...
-
【マクロ】変数に入れるコード...
-
エクセルシートの見出しの文字...
-
【マクロ】別ファイルへマクロ...
-
【関数】同じ関数なのに、エラ...
-
Amazonでマイクロソフトオフィ...
-
ページが変なふうに切れる
おすすめ情報