提示:其它语言是由 Google 机器翻译的。 你可以访问 English 版本。
登录
x
or
x
x
马上登记
x

or

如何在Excel中自动编号合并的单元格?

我们如何将系列号码填入Excel中不同大小合并单元格的列表中? 首先我们想要拖动自动填充句柄来填充合并的单元格,但在这种情况下,我们将收到以下警告消息,并且无法填充合并的单元格。

DOC-填充合并细胞,1

由于填充句柄不支持合并的单元格,在这里,我可以讨论一些解决此问题的其他技巧。

自动编号/使用VBA代码填充合并的单元格

Office选项卡在Office中启用选项卡式编辑和浏览,使您的工作更轻松......
Kutools for Excel - 最佳办公生产力工具将解决您的大部分Excel问题
  • 重用任何东西: 将最常用或最复杂的公式,图表和其他任何内容添加到您的收藏夹中,并在将来快速重复使用它们。
  • 超过20文本功能: 从文本字符串中提取数字; 提取或删除部分文本; 将数字和货币转换为英语单词...
  • 合并工具:多个工作簿和表格合二为一; 合并多个单元格/行/列而不丢失数据; 合并重复行和总和...
  • 拆分工具:根据价值将数据拆分为多个表格; 一个工作簿到多个Excel,PDF或CSV文件; 一列到多列......
  • 粘贴跳过 隐藏/过滤行; 数和总和 按背景颜色; 创建邮件列表和 通过Cell的价值发送电子邮件...
  • 超级过滤器: 创建高级过滤方案并应用于任何工作表; 排序 按周,日,频率等; 筛选 通过大胆,公式,评论......
  • 超过300强大的功能; 适用于Office 2007-2019和365; 支持所有语言; 在公司轻松部署; 全功能60天免费试用。

箭头蓝色右泡 自动编号/使用VBA代码填充合并的单元格


以下VBA代码可以帮助您快速为选定的合并单元格编号。 请做如下操作:

1。 按住 ALT + F11 键,然后打开 Microsoft Visual Basic for Applications窗口.

2。 点击 插页 > 模块,并将以下代码粘贴到 模块窗口.

VBA代码:自动编号合并单元格

Sub NumberCellsAndMergedCells()
	'Update 20141028
	Dim Rng As Range
	Dim WorkRng As Range
	On Error Resume Next
	xTitleId = "KutoolsforExcel"
	Set WorkRng = Application.Selection
	Set WorkRng = Application.InputBox("Range", xTitleId, WorkRng.Address, Type: = 8)
	Set WorkRng = WorkRng.Columns(1)
	xIndex = 1
	Set Rng = WorkRng.Range("A1")
	Do While Not Intersect(Rng, WorkRng) Is Nothing
		Rng.Value = xIndex
		xIndex = xIndex + 1
		Set Rng = Rng.MergeArea.Offset(1)
	Loop
End Sub

3。 然后按 F5 键来运行此代码,并弹出一个提示框让您选择要填充的合并单元格,请参阅截图:

DOC-填充合并细胞,1

4。 选择合并的单元格后,单击 OK,现在,您选择的合并单元格已填充了连续编号,请参阅屏幕截图:

DOC-填充合并细胞,1


相关文章:

如何在Excel中过滤后自动编号或重新编号?

如何在Excel中快速合并具有相同数据的相邻行?

如何取消合并单元格并在Excel中填入重复值?


Kutools for Excel - 最佳办公生产力工具提高80%的生产力

  • 重用: 快速插入 复杂的公式,图表 以及你以前用过的任何东西; 加密单元格 密码; 创建邮件列表 并发送电子邮件...
  • 超级方程式酒吧 (轻松编辑多行文字和公式); 阅读布局 (轻松读取和编辑大量单元格); 粘贴到过滤范围...
  • 合并单元格/行/列 不丢失数据; 分裂细胞含量; 组合重复的行/列...防止重复的细胞; 比较范围...
  • 选择复制或唯一 行; 选择空行 (所有细胞都是空的); 超级查找和模糊查找 在许多工作簿中; 随机选择......
  • 精确复制 多个单元格而不更改公式参考; 自动创建参考 多张表; 插入项目符号,复选框等等......
  • 提取文本,添加文本,按位置删除, 删除空间; 创建和打印分页小计; 在单元格内容和注释之间转换...
  • 超级过滤器 (将过滤方案保存并应用到其他工作表); 高级排序 按月/周/日,频率等; 特殊过滤器 用粗体,斜体......
  • 结合工作簿和工作表; 根据键列合并表; 将数据拆分为多个表格; 批量转换xls,xlsx和PDF...
  • 超过300强大的功能。 支持Office / Excel 2007-2019和365。 支持所有语言。 在您的企业或组织中轻松部署。 全功能60天免费试用。
kte tab 201905

Office选项卡为Office提供选项卡式界面,使您的工作更轻松

  • 在Word,Excel,PowerPoint中启用选项卡式编辑和阅读,Publisher,Access,Visio和Project。
  • 在同一窗口的新选项卡中打开并创建多个文档,而不是在新窗口中。
  • 通过50%提高您的工作效率,每天为您减少数百次鼠标点击!
官方底部

Say something here...
symbols left.
You are guest ( Sign Up? )
or post as a guest, but your post won't be published automatically.
Loading comment... The comment will be refreshed after 00:00.
  • To post as a guest, your comment is unpublished.
    Robin · 1 years ago
    Is there a way to exclude a merged cell that has text in it? This script works perfectly but I'm traversing a document that includes several horizontally merged cells that are made into title bars and I want to skip over/exclude those. Any help would be greatly appreciated!
  • To post as a guest, your comment is unpublished.
    piyush · 1 years ago
    This code is working perfectly.


    Sub NumberCellsAndMergedCells()
    'Update 20141028
    Dim Rng As Range
    Dim WorkRng As Range
    On Error Resume Next
    xTitleId = "KutoolsforExcel"
    Set WorkRng = Application.Selection
    Set WorkRng = Application.InputBox("Range", xTitleId, WorkRng.Address, Type: = 8)
    Set WorkRng = WorkRng.Columns(1)
    xIndex = 1
    Set Rng = WorkRng.Range("A1")
    Do While Not Intersect(Rng, WorkRng) Is Nothing
    Rng.Value = xIndex
    xIndex = xIndex + 1
    Set Rng = Rng.MergeArea.Offset(1)
    Loop
    End Sub


    BUT i want it to select range automatically instead of Set WorkRng = Application.Selection.
    Please help.
  • To post as a guest, your comment is unpublished.
    IVAN MARDEN · 1 years ago
    I purchased the Kutools so it would help me auto increment my invoice numbering but I am not seeing that feature in the add-in on the Excel tool bar. Maybe I'm not looking for the correct name but I am not finding how to insert this into my invoice template. Any out there
  • To post as a guest, your comment is unpublished.
    CD · 2 years ago
    Hi,

    was wondering if there is anyway to alter the code where the range value will increase by one e.g. I am trying to use this for invoices and the number should go from NR000026489 to NR000026490, but using the code above with the modification given to JYOTHI it would increase from NR000026489 to NR0000264810.
    Any help would be greatly appreciated as I've spent ages trying different things but am not advanced enough in VB.

    Thanks very much :)
  • To post as a guest, your comment is unpublished.
    Nrv · 2 years ago
    Modify:

    Do While Not Intersect(Rng, WorkRng) Is Nothing
    a = xIndex
    Rng.Value = "Tc_" & a
    xIndex = xIndex + 1
    Set Rng = Rng.MergeArea.Offset(1)
    Loop
  • To post as a guest, your comment is unpublished.
    Jyothi · 3 years ago
    It is very helpful.
    but I need one solution, suppose I want to fill series into merged cells but the content of merged cell have data like TC_01,
    Is it possible to fill next merged cells like TC_02, TC_03etc..
    If its possible it helps me a lot.
    Thanks in advance.
  • To post as a guest, your comment is unpublished.
    LR · 4 years ago
    This was really helpful and solved my problem immediately, thank you very much!