よろしくお願いします。
excelで連番を振りたいのですが、隣のセルに並んでいる
項目ごとに振りたいのです。VBAでできるでしょうか?
番号を振りたいのはB列で、名前ごとに1から順番に番号を
振りたいです。名前が変わるとまた1に戻って、振っていき、
A列がなくなると終了です。
A列の名前の数や、それぞれのデータ数、
全体のデータ数などは、ばらばらです。
もしかしたら列数はかわるかも知れませんが、
隣の列の項目ごとに番号を1から振る、ということは
変わりません。
(A列) (B列)
山田 1
山田 2
山田 3
田中 1
田中 2
田中 3
田中 4
佐藤 1
佐藤 2
加藤 1
斎藤 1
斎藤 2
斎藤 3
斎藤 4
斎藤 5
・ ・
・ ・
・ ・
今は目で見ながら毎日、オートフィルタでがんばっています。
これができるとすごくうれしいです。
よろしくお願いいたします。
No.3
- 回答日時:
ご希望のVBAです
---------------
Sub Mc1()
Nb = 1
Cells(1, 2) = Nb
ex = Range("A" & Rows.Count).End(xlUp).Row
For i = 2 To ex
If Cells(i, "A") = Cells(i - 1, "A") Then
Nb = Nb + 1
Else
Nb = 1
End If
Cells(i, "B") = Nb
Next
End Sub
さっそくの回答ありがとうございました。
ポイントは今回先着の方に差し上げますが、
本当は皆様に差し上げたいです。
ありがとうございました。
No.2
- 回答日時:
(1)VBAでなくてもエクセル関数COUNTIFでできる。
VBAでやる事情があるのか。
(2)(1)の関数をVBA化することも可能。
Sub test01()
d = Range("A65536").End(xlUp).Row
For i = 1 To d
c = WorksheetFunction.CountIf(Range("A1:A" & i), Cells(i, "A"))
Cells(i, "B") = c
MsgBox c
Next i
End Sub
例データ
堺1
境1
サカイ1
堺2
境2
境3
ーーー
(3)名前列でソートして、直前の名前を、毎行において、見て
A。同じなら前の番号(変数に保持する手もある。前行のB列セル)に+1
B変わったら1を
振れば仕舞いではないか。
(4)ソートしないなら、Find,FindNextで(例)山田を順次捕らえて連番を振って行く手もある。
ソート方に持ち込むのが簡単になって賢明。
countifでできるんですね、おっしゃいますように
VBAでやらなければならないということはありません。
でもVBAも勉強中なので、コードは非常に参考になります。
ありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) EXCEL 関数を教えてください。(A列の同じ値が複数ある場合vlookupで出来ますか) 4 2022/12/07 20:54
- Excel(エクセル) エクセルの条件付き書式 個人シートを参照して集計シートに色付けしたい 1 2023/06/22 00:39
- 野球 藤田元司は巨人の名将? 3 2022/11/07 19:51
- Excel(エクセル) Excelマクロ 差分抽出の方法が知りたいです。 2 2023/03/07 13:25
- 野球 澤村、金田、稲尾、杉浦、山田久江夏、斎藤雅、伊藤智、野茂、松坂、ダルビッシュ等、山本由等々数々の名投 2 2023/02/10 10:03
- その他(暮らし・生活・行事) お墓に関してですが、、、 父親が山田ら母親の旧姓が斎藤だとします。 父親が死んだ場合、山田の墓に入る 4 2023/06/18 13:24
- ドラマ 壬生義士伝 1 2023/01/02 13:12
- Visual Basic(VBA) リストポックス検索 1 2022/06/19 21:32
- 計算機科学 Excel ある行と列が交わったところにマークを付けるには 7 2023/01/24 08:46
- Excel(エクセル) 範囲指定をした中で、住所の列をユーザー設定の並べ替えをしたい 3 2022/05/15 13:51
このQ&Aを見た人はこんなQ&Aも見ています
-
プロが教えるわが家の防犯対策術!
ホームセキュリティのプロが、家庭の防犯対策を真剣に考える 2組のご夫婦へ実際の防犯対策術をご紹介!どうすれば家と家族を守れるのかを教えます!
-
ExcelのVBAで連番を振る。
Excel(エクセル)
-
Excel VBA 自動で連番をわりふる
Excel(エクセル)
-
Excel VBAで条件ごとの自動採番について
Excel(エクセル)
-
-
4
グループごとに連番をふる
Visual Basic(VBA)
-
5
【EXCEL】【VBA】空欄は飛ばして処理する方法を教えて下さい。
Excel(エクセル)
-
6
Excel VBAでオートフィルタで抽出した列データを別シートの最終行にコピーするには
Visual Basic(VBA)
-
7
【Excel VBA】指定行以降をクリアするには?
Visual Basic(VBA)
-
8
エクセルのエラーメッセージ「400」って?
Visual Basic(VBA)
-
9
ExcelVBAを使って、値がある場合は作業を繰り返し実行するプログラムを作成したい。
Visual Basic(VBA)
-
10
エクセル グループ毎に番号(連番)を振りたいです。但し、同じデータには同じ番号を振りたいのです。
Excel(エクセル)
-
11
VBAで重複データを合算したい
Excel(エクセル)
-
12
VBA Cのセルが空白でなかったら、Aのセルに順番に数値を入力
Visual Basic(VBA)
-
13
i=cells(Rows.Count, 1)とi=cells(Rows.Count, 2)の違い
Visual Basic(VBA)
-
14
エクセルである行以下全部を削除する方法
Excel(エクセル)
-
15
VBAで空白セルにのみ数値を代入する方法
Excel(エクセル)
-
16
VBAでの結合セルのコピー&ペースト
Excel(エクセル)
-
17
エクセルのマクロで、選択範囲の空白行を削除する方法
Excel(エクセル)
-
18
エクセル:マクロ「Application.CutCopyMode = False」って?
Excel(エクセル)
-
19
別のシートから値を取得するとき
Visual Basic(VBA)
-
20
エクセル 日付による並べ替えのマクロ
Excel(エクセル)
関連するカテゴリからQ&Aを探す
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Excel関数-文字列で自動作成さ...
-
エクセルの関数について教えて...
-
Excelデータをコピペして、ペー...
-
職場の人から聞かれており、こ...
-
ユーザー定義関数をアドイン登...
-
Excelで50個のセルに同じ文字を...
-
スプレッドシート、Excelでの数...
-
Microsoft Officeの中古は信用...
-
エクセルで不等号記号(≠)が上に...
-
スプレッドシートで使う数式を...
-
エクセルでの特別な文字を上に...
-
エクセル日付 文字列の関数がエ...
-
A列とB列を参照してC列に連番を...
-
エクセルVBA、別ブックへ転記す...
-
各ページの1番上の表示について
-
エクセルでセルに標準で入力さ...
-
EXCELの質問です 119から足した...
-
pdfの表をexcelにはりつけて計...
-
Excelのif関数で文字が見えなく...
-
【マクロ】アクティブセルにブ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルVBA、別ブックへ転記す...
-
エクセルでの作業計算方法について
-
時間によってファイル名が変わ...
-
【関数】適切な文字数の数字を...
-
Excelについて教えてください
-
エクセル初心者です 関数の入れ...
-
【マクロ】ファイル名の変更に...
-
UNIQUE関数が使えないバージョ...
-
エクセルの計算
-
【関数】先頭だけにある、半角...
-
Excelで、決まった行を繰り返し...
-
Excelでセルの値が同じか...
-
LOOKUP関数を使えばいいのでし...
-
Excel
-
はがきについて。
-
エクセルの条件付き書式につい...
-
エクセルのデーターが2か月前の...
-
エクセル②
-
エクセルで「-0.0」と表示さ...
-
Microsoft1Officeの互換ソフト...
おすすめ情報