同じ品番で、マスタの番号が変わるデータが、毎日更新されているとします。
品番で最新日付のマスタがわかるように〇印をつけたいです。(画像参照)
配列関数で
{=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も見ています
関連するカテゴリからQ&Aを探す
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルの関数について教えて...
-
Excelカスタム関数(アドイン登...
-
Excelデータをコピペして、ペー...
-
Excel関数-文字列で自動作成さ...
-
スプレッドシート、Excelでの数...
-
Excelで50個のセルに同じ文字を...
-
Microsoft Officeの中古は信用...
-
スプレッドシートで使う数式を...
-
エクセルVBA、別ブックへ転記す...
-
エクセルで会社の従業員のデー...
-
エクセルで不等号記号(≠)が上に...
-
エクセルの表で1年間の曜日を...
-
A列とB列を参照してC列に連番を...
-
エクセルの空欄をつめて、次の...
-
エクセルでの特別な文字を上に...
-
エクセルでセルに標準で入力さ...
-
エクセル日付 文字列の関数がエ...
-
エクセル2013で月間勤務表から...
-
エクセルの日付を編集する
-
EXCELの質問です 119から足した...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルVBA、別ブックへ転記す...
-
エクセルでの作業計算方法について
-
時間によってファイル名が変わ...
-
【関数】適切な文字数の数字を...
-
Excelについて教えてください
-
エクセル初心者です 関数の入れ...
-
【マクロ】ファイル名の変更に...
-
UNIQUE関数が使えないバージョ...
-
エクセルの計算
-
【関数】先頭だけにある、半角...
-
Excelで、決まった行を繰り返し...
-
Excelでセルの値が同じか...
-
LOOKUP関数を使えばいいのでし...
-
Excel
-
はがきについて。
-
エクセルの条件付き書式につい...
-
エクセルのデーターが2か月前の...
-
エクセル②
-
エクセルで「-0.0」と表示さ...
-
Microsoft1Officeの互換ソフト...
おすすめ情報