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

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

新規登録して質問してみよう
ただいま回答率
85.48%
関数

関数(ファンクション・メソッド・サブルーチンとも呼ばれる)は、はプログラムのコードの一部であり、ある特定のタスクを処理するように設計されたものです。

Q&A

解決済

2回答

548閲覧

エクセルで各データの個数を集計し、個数順に並べたい

nekoyama771

総合スコア29

関数

関数(ファンクション・メソッド・サブルーチンとも呼ばれる)は、はプログラムのコードの一部であり、ある特定のタスクを処理するように設計されたものです。

1グッド

0クリップ

投稿2022/05/15 03:07

編集2022/05/15 07:15

商品名を記載したデータがあります。

商品
ぶどう
みかん
みかん
レモン
なし
なし
みかん
ぶどう

このデータを商品の個数順でまとめ、個数順に並べ替えたいです。
可能であれば関数のみで行いたいです。
(個数が同数の場合の表示順に指定はありません)

商品個数
みかん3
ぶどう2
なし2
レモン1
 
 

※下に空白列が続いても可


各商品の初出列を出す方法で、個数ごとに集計まではできたのですが、
その後、E列・F列の表を値のみ貼り付けしてソートが必要です。
(E列・F列にも数式が入っているため、ソートしても並び順が変わらないため)
E列・F列の表を参照し、LARGE関数などを使い、新しい表を作れば、
個数順に並び替えた表ができそうですが、作り方が分かりません。

※B列の式 =IF(COUNTIF(B$2:B2,B2)=1,ROW(),"")
※E列の式 =IF(ROW(A1)<=COUNT(B$2:B$9),INDEX(A:A,SMALL(B$2:B$9,ROW(A1)),0),"")
※F列の式 =IF(E2<>"",COUNTIF(test!A$2:A$9,E2),"")

ABCDEF
1商品初出列商品個数
2ぶどう2  ぶどう2
3みかん3  みかん3
4みかん  レモン1
5レモン5  なし2
6なし6
7なし
8みかん
9ぶどう

各商品の個数をカウントする方法から作る方法もあると思いますが、
こちらも進め方が分かりません。
※B列の式 =COUNTIF(A$2:$A$9,A2)

AB
1商品個数
2ぶどう2
3みかん3
4みかん3
5レモン1
6なし2
7なし2
8みかん3
9ぶどう2

Excelのバージョンは2013です。
作業列の使用、表の作成に制限はありません。
よろしくお願いします。

kadoyaca1👍を押しています

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

イメージ説明

[B2] =IF(COUNTIF(A$2:A2,A2)>1,"",COUNTIF(A$2:A$9,A2))
[C2] =IFERROR(B2+ROW()*0.0001,"")
[D2] =LARGE(C$2:C$9,ROW()-1)
[E2] =MATCH(D2,C$2:C$9,0)

[G2] =IFERROR(INDEX(A$2:A$9,$E2),"")
[H2] =IFERROR(INDEX(B$2:B$9,$E2),"")

@jinojiさんの回答のパクりです。
エラーとなる部分を修正し、分かり易く整理したものになります。
なのでベストアンサーは辞退します。

投稿2022/05/17 12:14

takanaweb5

総合スコア358

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

nekoyama771

2022/06/12 12:58

エラーの修正・内容整理、ありがとうございます。 助かりました。
guest

0

ベストアンサー

手元に2013がないのでちゃんと確認できませんが、こんな感じでどうでしょう。

[B2] =IF(COUNTIF($A1:$A2)>1,"",COUNTIF($A$2:$A$9,$A2)) [C2] =IF(LEN($B2)=0,"",$B2+1-ROW()*0.00001) [E2] =IFERROR(INDEX($A$2:$A$9,MATCH(LARGE($C$2:$C$9,ROW()-1,$C$2:$C$9,0)),"") [F2] =IF(LEN($E2)=0,"",COUNTIF($A$2:$A$9,$E2)) ※それぞれの数式は行数分コピーしてください

なお、最新のExcelやMicrosoft365だとこんな感じです。

[E2] =SORTBY(UNIQUE(A2:A9),COUNTIF(A2:A9,UNIQUE(A2:A9)),-1) [F2] =COUNTIF(A2:A9,E2#)

投稿2022/05/15 14:18

jinoji

総合スコア4585

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

nekoyama771

2022/06/12 12:59

ありがとうございました。 お二人の回答で解決できました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問