跳至主要内容

如何在Excel中重复单元格值,直到看到或达到新值?

Author: Siluvia Last Modified: 2025-07-31

如左图所示,您需要在Excel的某一列中重复单元格值,直到看到或达到新值。在这种情况下,您需要在后续的空白单元格中重复值A,直到达到值B,并重复值B直到看到值C。如何实现这一点?本文将帮助您解决这个问题。

A screenshot showing initial data in Excel with values to be repeated down until a new value appears

使用公式重复单元格值,直到看到或达到新值
通过引用上方的值来重复单元格值,直到看到或达到新值
使用VBA代码重复单元格值,直到看到或达到新值
只需几次点击即可轻松重复单元格值,直到看到或达到新值


使用公式重复单元格值,直到看到或达到新值

您可以使用公式在Excel中重复单元格值,直到看到新值。请按照以下步骤操作。

1. 在新列中,选择一个与需要重复其值的单元格(E2)相邻的空白单元格,然后在编辑栏(F)中输入公式 =E2并按Enter键。参见截图:

A screenshot showing the start of repeating values with a formula in an adjacent column in Excel

2. 选择辅助列中的下一个单元格(F3),在编辑栏(F)中输入公式=IF(E3="",F2,E3),然后按Enter键。

A screenshot of using a formula to repeat cell values until a new value is seen in Excel

3. 继续选择单元格F3,向下拖动填充柄以重复所有单元格值,直到看到新值。参见截图:

A screenshot showing repeated cell values achieved with the Fill Handle in Excel


在Excel中轻松重复单元格值,直到达到新值:

Kutools for Excel填充空白单元格工具可以帮助您在Excel列表中重复单元格值,直到看到或达到新值,如下方截图所示。立即下载并试用!

A screenshot showing the final output where cell values are repeated using Kutools for Excel’s Fill Blank Cells utility


通过引用上方的值来重复单元格值,直到看到或达到新值

除了上述公式外,您可以先选择所有空白单元格,然后通过快捷键引用所有上方的值来填充空白单元格。

1. 选择需要重复单元格值的列,然后按F5键打开定位至对话框,然后单击特殊按钮。

A screenshot of the Go To dialog box in Excel to select blank cells in the column

2. 在 定位至特殊对话框中,选择空白选项,然后单击确定按钮。参见截图:

A screenshot of selecting blank cells in Excel to fill with the value above

3. 现在已选择了所选列中的所有空白单元格,请输入等号=,按一次向上箭头键,然后同时按下Ctrl + Enter键。

A screenshot of using the fill command with Ctrl + Enter to repeat values in blank cells

然后,您可以看到所选列中的单元格值被重复,直到看到新值,如下方截图所示:

A screenshot of completed repeated values in Excel using the reference above method


使用VBA代码重复单元格值,直到看到或达到新值

以下VBA代码还可以帮助您在Excel的特定列中重复单元格值,直到看到新值。

1. 选择需要重复单元格值直到看到新值的列范围,然后同时按下Alt + F11键打开Microsoft Visual Basic for Applications窗口。

2. 在Microsoft Visual Basic for Applications窗口中,单击插入 > 模块。然后复制并将以下VBA代码粘贴到模块窗口中。

VBA代码:在Excel中重复单元格值,直到看到新值

Sub FillDown()
Dim xRng As Range
Dim xRows As Long, xCols As Long
Dim xRow As Integer, xCol As Integer
Set xRng = Selection
xCols = xRng.Columns.CountLarge
xRows = xRng.Rows.CountLarge
For xCol = 1 To xCols
  For xRow = 1 To xRows - 1
    If xRng.Cells(xRow, xCol) <> "" Then
      xRng.Cells(xRow, xCol) = xRng.Cells(xRow, xCol).Value
      If xRng.Cells(xRow + 1, xCol) = "" Then
        xRng.Cells(xRow + 1, xCol) = xRng.Cells(xRow, xCol).Value
      End If
    End If
  Next xRow
Next xCol
End Sub

3. 按F5键运行代码。然后,所选列范围内的所有空白单元格都会立即以上方的值填充。


只需几次点击即可轻松重复单元格值,直到看到或达到新值

本节将介绍Kutools for Excel填充空白单元格工具。使用此工具,您只需几次点击即可轻松重复单元格值,直到看到新值。

Kutools for Excel 提供了超过 300 种高级功能,简化复杂任务,提升创造力与效率。 通过集成 AI 能力,Kutools 能够精准自动执行任务,让数据管理变得轻松简单。Kutools for Excel 的详细信息...         免费试用...

1. 选择需要重复单元格值的列范围,然后单击Kutools > 插入 > 填充空白单元格。参见截图:

A screenshot showing the Fill Blank Cells option on the Kutools tab on the ribbon

2. 在填充空白单元格对话框中,在 填充方式部分选择基于值,在选项部分选择向下选项,最后单击确定按钮。参见截图:

A screenshot of the Fill Blank Cells dialog

然后,所有空白单元格会立即以上方单元格值填充,如下方截图所示。

A screenshot showing the result of repeating values using Kutools for Excel

Kutools for Excel - 通过超过300个必备工具,让Excel功能大幅提升。永久免费享受AI功能!立即获取


演示:使用Kutools for Excel轻松重复单元格值,直到看到或达到新值

Kutools for Excel:超过 300 种实用工具触手可及!永久免费享受 AI 功能!立即下载!

相关文章

最佳 Office 办公效率工具

🤖 Kutools AI 助手:基于智能执行,彻底革新数据分析 生成代码创建自定义公式分析数据并生成图表调用 Kutools Functions
热门功能:查找、选中项的背景色或标记重复项|删除空行|合并列或单元格且不丢失数据|四舍五入(无公式)...
高级 LOOKUP多条件查找 (VLookup)多值查找 (VLookup)多表查找 (VLookup Across Multiple Sheets)模糊查找 (Fuzzy Lookup)...
高级下拉列表快速创建下拉列表依赖型下拉列表多选下拉列表...
列管理器添加指定数量的列移动列切换隐藏列的可见状态比较区域及列...
特色功能网格聚焦设计视图增强编辑栏工作簿 & 工作表管理器资源库(自动文本)|日期提取合并数据加密/解密单元格按列表发送电子邮件超级筛选特殊筛选(筛选粗体/倾斜/删除线等)...
热门15 大工具集12 款文本工具添加文本删除特定字符等)50+ 种图表 类型甘特图等)40+ 实用公式基于生日计算年龄等)19 款插入工具插入二维码按路径插入图片等)12 种转换工具小写金额转大写汇率转换等)7 款合并与分割工具高级合并行分割单元格等)...更多精彩等你发现
使用 Kutools,支持您的首选语言——包括英语、西班牙语、德语、法语、中文及40 多种其他语言!

用 Kutools for Excel 加速你的 Excel 技能,体验前所未有的高效办公。 Kutools for Excel 提供300 多项高级功能,助您提升效率,节省大量时间。点击此处,获取你最需要的功能...


Office Tab 为 Office 带来标签式界面,让你的工作更加轻松

  • 在 Word、Excel、PowerPoint 启用标签式编辑和阅读
  • 在同一窗口的新标签中打开和创建多个文档,无需新建窗口。
  • 办公效率提升50%,每天帮你减少上百次鼠标点击!