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

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

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

Q&A

解決済

3回答

2545閲覧

エクセルの関数を使って連番をつけたいです。

退会済みユーザー

退会済みユーザー

総合スコア0

0グッド

1クリップ

投稿2020/06/23 12:16

編集2020/06/23 15:00

以下の画像のB列のような採番を手入力ではなく、エクセルの関数を使用して自動で入るようにしたいです。

イメージ説明

B列のNo.以下をx-y-zの形式で入れたいです。
xは学校ごとに番号が振られ、yは各学校の部活ごとに振られ、
zは各部活の部員氏名ごとに振られます。
(部活項目は他校と同じ部活があっても同じ番号ではなくて良いです。)

9,10行目の間に挿入して××中学校、テニス部、鈴木一郎を入れたら2-2-1が振られる。

補足
xは=SUMPRODUCT(1/COUNTIF(C$4:C4,C$4:C4))
zは=COUNTIF(D$4:D4,D4)

でできました。

=SUMPRODUCT(1/COUNTIF(C$4:C4,C$4:C4))&"-"&(yの関数)&"-"&COUNTIF(D$4:D4,D4)
私のイメージはこんな感じです。

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

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

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

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

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

guest

回答3

0

ベストアンサー

作業列なしでも可能ですが、後で非表示とする作業列を作って処理した方がシンプルな式になります。

zは=COUNTIF(D$4:D4,D4)

これだと、学校が違っても同じ部活だと カウント数が増えてしまいます。
この式を適用すると 12行目は 3-2-2 となります。

よって、作業列+ifでやるのが簡単かなと。
G,H,I をそれぞれ x,y,z の自動連番用の作業列とした場合、IFを使うことで対応可能です。

Excle関数

1//x (作業列G) 2=SUMPRODUCT(1/COUNTIF(C$4:C4,C$4:C4)) 3//または 4=IF(C3=C4,G3,G3+1) 5 6 7//y (作業列H) 8=IF(C3=C4,IF(D3=D4,H3,H3+1),1) 9 10//z (作業列I) 11=IF(D3=D4,IF(C3=C4,I3+1,1),1) 12 13// No. (B列) 14=TEXTJOIN("-",TRUE,G4:I4) 15

それぞれ G4,H4,I4 と B4に入れて、あとはコピぺ。

投稿2020/06/24 04:41

編集2020/06/24 04:52
sawa

総合スコア3002

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

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

退会済みユーザー

退会済みユーザー

2020/06/24 13:29

ありがとうございます。 やりたいことができました。 作業場所無しで一つのセルに完結させたかったので、いただいたものをもとに別回答として記載させていただきました(だいぶ長くなってしまいました。)
guest

0

遣りたい事はこんな感じと思われます。
イメージ説明

Excel関数

1=VLOOKUP(C3,$C$14:$D$16,2,FALSE)&"-"&VLOOKUP(D3,$D$19:$E$23,2,FALSE)&"-"&VLOOKUP(E3,$E$26:$F$34,2,FALSE)

投稿2020/06/24 00:01

編集2020/06/24 00:06
tosi

総合スコア553

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

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

退会済みユーザー

退会済みユーザー

2020/06/24 13:33

tosi様、ご回答いただきありがとうございます。 sawa様のご回答が私の求めていた内容に近かったのでベストアンサーとさせていただきました。
guest

0

以下で一応動きました。

=TEXTJOIN("-",TRUE,SUMPRODUCT(1/COUNTIF(C$4:C4,C$4:C4)),IF(C3=C4,IF(D3=D4,MID(B3,FIND("-",P3)+1,FIND("●", SUBSTITUTE(B3, "-", "●", LEN(B3) - LEN(SUBSTITUTE(B3, "-", ""))))-FIND("-",B3)-1),MID(B3,FIND("-",B3)+1,FIND("●", SUBSTITUTE(B3, "-", "●", LEN(B3) - LEN(SUBSTITUTE(B3, "-", ""))))-FIND("-",B3)-1)+1),1),IF(D3=D4,IF(C3=C4,MID(P3,FIND("●", SUBSTITUTE(B3, "-", "●", LEN(B3) - LEN(SUBSTITUTE(B3, "-", ""))))+1,LEN(B3)-FIND("●", SUBSTITUTE(B3, "-", "●", LEN(B3) - LEN(SUBSTITUTE(B3, "-", "")))))+1,1),1))

投稿2020/06/24 13:30

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.49%

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

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

質問する

関連した質問