KutoolsforOffice — 一套方案,五大工具。事半功倍。

如何在 Excel 中提取第二个空格或逗号之前或之后的内容?

作者Xiaoyang修改日期

在 Excel 中处理文本数据时,您经常会遇到包含多个空格、逗号或其他分隔符的字符串。虽然 Excel 的文本分列功能可根据选定的分隔符将单元格内容拆分为多列,但有时您需要更精准的解决方案——例如提取单元格中第二个空格或逗号之前或之后的所有内容。本文为您介绍几种实用方法:包括针对第二个空格/逗号前后文本的高效公式、适用于自动化或大型数据集的稳健 VBA 宏方案,以及用于高级数据预处理的灵活 Power Query 选项。

原始文本字符串及由第二个空格分隔的两个片段的截图

使用公式提取提取文本第二个空格或逗号之前的内容

使用公式提取提取文本第二个空格或逗号之后的内容

使用 VBA 代码提取提取文本第二个分隔符(空格/逗号)之前或之后的内容


使用公式提取提取文本第二个空格或逗号之前的内容

若要提取单元格中第二个空格之前的内容,可灵活组合使用 Excel 函数。

1. 将以下公式输入到您希望显示结果的空白单元格中(例如单元格 )C2):

=IF(ISERROR(FIND(" ",A2,FIND(" ",A2,1)+1)),A2,LEFT(A2,FIND(" ",A2,FIND(" ",A2,1)+1)))

2. 按 Enter,然后使用填充柄向下拖动公式,即可应用到所有需要处理的行。结果将显示每行中第二个空格之前的所有文本——如下图所示:

提示如果您希望在第二个逗号或其他分隔符之前提取文本,只需将公式中的空格字符()" ")替换为您所需的分隔符即可。例如,使用逗号时:

=IF(ISERROR(FIND(",",A2,FIND(",",A2,1)+1)),A2,LEFT(A2,FIND(",",A2,FIND(",",A2,1)+1)))

此方法适用于一次性提取或处理中等规模数据集,操作快捷高效。然而,若文本格式高度不规则,或各行分隔符数量差异较大,则可能需对公式进行额外调整。此外,请留意多余的空格或空单元格可能影响结果;处理关键数据时,务必仔细核对输出内容。

kutools for excel ai 的截图

借助 KUTOOLS AI 解锁 Excel 的神奇功能

  • 智能执行:只需输入简单命令,即可执行单元格操作、分析数据并创建图表。
  • 自定义公式:生成量身定制的公式,助您优化工作流程!
  • VBA 编码:轻松编写并运行 VBA 代码。
  • 公式解析:轻松掌握复杂公式,一目了然!
  • 文本翻译:轻松打破电子表格中的语言障碍!
借助 AI 驱动的工具提升您的 Excel 能力。立即下载,体验前所未有的高效!

使用公式提取提取文本第二个空格或逗号之后的内容

要提取单元格中第二个空格分隔符之后的内容,可结合使用 MID 函数与 FIND 函数。

1. 将以下公式输入到目标单元格(例如 D2)中:

=MID(A2, FIND(" ", A2, FIND(" ", A2)+1)+1,256)

2. 按 Enter 键,然后向下拖动填充柄,覆盖所有需要提取的行,即可显示每行中第二个空格之后的所有内容,如下图所示:

提示若要在第二个逗号或任意其他分隔符之后提取文本,请将公式中的空格字符替换为您所需的分隔符。以逗号为例,公式如下:

=MID(A2, FIND(",", A2, FIND(",", A2)+1)+1,256)

使用 VBA 代码提取提取文本第二个分隔符(空格/逗号)之前或之后的内容

对于大型数据集、重复提取或自动化场景,使用 VBA 宏是一种高效之选。VBA 能帮您精准提取第二个空格、逗号或其他任意分隔符之前或之后的内容,显著提升处理不同数据结构或执行可重复任务时的效率。

1. 选择开发工具>Visual Basic。在弹出的 Microsoft Visual Basic for Applications 窗口中,单击插入> 模块,并将以下代码粘贴到模块窗口中:

Sub ExtractTextSecondDelimiter()
    Dim rng As Range
    Dim cell As Range
    Dim sep As String
    Dim direction As String
    Dim arr As Variant
    Dim result As String
    Dim pos1 As Long
    Dim pos2 As Long
    Dim xTitleId As String
    Dim outputCell As Range
    Dim i As Long
    On Error Resume Next
    xTitleId = "KutoolsforExcel"
    Set rng = Application.Selection
    Set rng = Application.InputBox("Select text range to extract from", xTitleId, rng.Address, Type:=8)
    If rng Is Nothing Then Exit Sub
    sep = Application.InputBox("Enter delimiter (e.g. space or comma)", xTitleId, " ", Type:=2)
    If sep = "" Then Exit Sub
    direction = Application.InputBox("Type 'before' for text before, 'after' for text after the 2nd delimiter", xTitleId, "before", Type:=2)
    If direction = "" Then Exit Sub
    Set outputCell = Application.InputBox("Select the first cell to output the result", xTitleId, Type:=8)
    If outputCell Is Nothing Then Exit Sub
    Application.ScreenUpdating = False
    i = 0
    For Each cell In rng
        If Not IsEmpty(cell.Value) Then
            pos1 = InStr(1, cell.Value, sep)
            If pos1 > 0 Then
                pos2 = InStr(pos1 + 1, cell.Value, sep)
                If pos2 > 0 Then
                    If LCase(direction) = "before" Then
                        result = Left(cell.Value, pos2 - 1)
                    ElseIf LCase(direction) = "after" Then
                        result = Mid(cell.Value, pos2 + Len(sep))
                    Else
                        result = cell.Value
                    End If
                Else
                    result = cell.Value
                End If
            Else
                result = cell.Value
            End If
            outputCell.Offset(i, 0).Value = result
        End If
        i = i + 1
    Next
    Application.ScreenUpdating = True
    MsgBox "Extraction completed.", vbInformation, xTitleId
End Sub

2. 粘贴代码后,单击运行按钮运行按钮,或按 F5 执行。系统将弹出对话框,提示您选择数据区域,输入分隔符,指定要提取“之前”还是“之后”的文本,并选择一个单元格输出结果。宏将在您指定的单元格中显示提取结果。


最佳办公效率工具

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

使用 Kutools for Excel 大幅提升您的 Excel 技能,体验前所未有的高效。Kutools for Excel 提供 300 多项高级功能,助您提升生产力、节省时间。立即点击此处,获取您最需要的功能……


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

  • 在 Word、Excel、PowerPoint、Publisher、Access、Visio 和 Project 中启用标签式编辑和阅读
  • 在同一个窗口的新标签页中打开并创建多个文档,而非在新窗口中。
  • 将您的工作效率提升 50%,每天减少数百次鼠标点击!

所有 Kutools 插件,一个安装程序

Kutools for Office 套件捆绑了适用于 Excel、Word、Outlook 和 PowerPoint 的插件以及 Office Tab Pro,非常适合需要跨多个 Office 应用高效协作的团队。

ExcelWordOutlookTabsPowerPoint
  • 一体化套件— Excel、Word、Outlook 和 PowerPoint 插件 + Office Tab Pro
  • 一个安装程序,一个许可证— 几分钟内完成设置(支持 MSI)
  • 协同效果更佳— 在多个 Office 应用中实现高效协同
  • 30 天全功能试用— 无需注册,无需信用卡
  • 超值之选— 比单独购买插件更省钱