
同じ品番で、マスタの番号が変わるデータが、毎日更新されているとします。
品番で最新日付のマスタがわかるように〇印をつけたいです。(画像参照)
配列関数で
{=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で質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) IFERROR、SMALL関数について 2 2022/08/22 23:40
- Excel(エクセル) Excel関数 情報引用する方法 4 2022/07/31 20:59
- Visual Basic(VBA) VBAで最新のデータを別シートに転記する方法をお教えください。 3 2022/04/07 19:20
- Visual Basic(VBA) 3つのプロシージャをまとめたら実行時エラー発生で対応不能 6 2022/05/17 01:47
- Visual Basic(VBA) ファイル全てを .xlsm に変更したところ、プログラムが途中で落ちてしまっています 17 2022/12/07 12:03
- Excel(エクセル) エクセルの条件付き書式 個人シートを参照して集計シートに色付けしたい 1 2023/06/22 00:39
- Excel(エクセル) 【条件付き書式】countifsで複数条件を満たしたセルを赤くする方法 2 2023/02/09 23:53
- Excel(エクセル) SUMIFのIF分岐について 4 2023/04/15 12:57
- Excel(エクセル) 製品番号での整列と、検索に関して 3 2023/06/28 19:20
- Excel(エクセル) VBA でvlookup エラーなどは削除したい 8 2022/12/30 04:03
このQ&Aを見た人はこんなQ&Aも見ています
-
Excelで同じ商品名で、かつ日付が古いものを抽出する方法
Excel(エクセル)
-
【EXCEL】条件に一致した最新の日付の売上を抽出
その他(Microsoft Office)
-
最新の日付をVLOOKUP
Word(ワード)
-
-
4
エクセルで最新の日付に色をつける
Excel(エクセル)
-
5
【EXCEL】条件に一致した最新データのみを抽出
その他(Microsoft Office)
-
6
EXCELで直近の日付を抽出する関数
Excel(エクセル)
-
7
エクセルで複数条件を満たす時、n番目に新しい日付を返す
Excel(エクセル)
-
8
excel 最新のデータ(行)を抽出する関数
Excel(エクセル)
-
9
マクロ オートフィルタの検索値を所定のセルから参照
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルのVBAで集計をしたい
-
【関数】同じ関数なのに、エラ...
-
【マクロ】【配列】3つのシー...
-
vba テキストボックスとリフト...
-
【画像あり】オートフィルター...
-
Office2021のエクセルで米国株...
-
【マクロ】元データと同じお客...
-
【マクロ】実行時エラー '424':...
-
【マクロ】数式を入力したい。...
-
【マクロ】【相談】Excelブック...
-
【マクロ】列を折りたたみ非表...
-
他のシートの検索
-
【条件付き書式】シートの中で...
-
ページが変なふうに切れる
-
【マクロ】オートフィルターの...
-
特定のセルだけ結果がおかしい...
-
エクセル ドロップダウンリスト...
-
【マクロ】アクティブセルの時...
-
【マクロ】3行に上から下に並...
-
9月17日でサービス終了らし...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
9月17日でサービス終了らし...
-
エクセル
-
【マクロ】WEBシステムから保存...
-
エクセルの循環参照、?
-
エクセル ドロップダウンリスト...
-
エクセルのdatedif関数を使って...
-
特定のセルだけ結果がおかしい...
-
【マクロ】A列にある、日付(本...
-
【マクロ】EXCELで読込したCSV...
-
【マクロ】アクティブセルの時...
-
【エクセル】期限アラートについて
-
iPhoneのExcelアプリで、別のシ...
-
【関数】同じ関数なのに、エラ...
-
Excelの新しい空白のブックを開...
-
【マクロ】3行に上から下に並...
-
【マクロ】宣言は、何のために...
-
VBA チェックボックスをオーバ...
-
Excelについての質問です 並べ...
-
【マクロ】アクティブセルの2...
-
【関数】不規則な文章から●●-●●...
おすすめ情報