跳至主要内容

如何在Excel中将逗号分隔的文本字符串转换为列表?

Author: Xiaoyang Last Modified: 2025-07-31
convert comma separated text string to list

在Excel中,将逗号分隔的文本字符串转换为列表或行是一项常见任务,尤其是在处理从CSV文件或其他文本来源导入的数据时。以下是一个详细的指南,向您介绍使用Excel内置功能和公式实现此操作的各种方法。

在Excel中将逗号分隔的文本字符串转换为列表


使用公式将逗号分隔的文本字符串转换为列表(Excel 365)

对于使用Excel 365的用户,TEXTSPLIT函数是一种高效且直接的方法,可以将逗号分隔的字符串转换为行或列。该函数会根据输出大小自动调整单元格范围(溢出结果)。

单击您希望结果开始的单元格,输入以下公式并按Enter键。包含逗号分隔文本字符串的单元格将立即转换为列表。请参见截图:

=TRANSPOSE(TEXTSPLIT(TEXTJOIN(", ", TRUE, A1:A4), ", "))

convert comma separated text string to list with a formula

此公式的解释:
  • TEXTJOIN(", ", TRUE, A1:A4): 这部分将A1到A4单元格中的文本值合并为一个字符串,并用逗号和空格(, )分隔。TRUE参数确保忽略范围内的空白单元格。
  • TEXTSPLIT(..., ", "): 使用逗号和空格(, )作为分隔符,将TEXTJOIN生成的组合字符串重新拆分为单独的项目。这将创建一个原始值的数组。
  • TRANSPOSE(...): 最后,TRANSPOSE函数将数组从垂直列翻转为水平行(或者反之,取决于原始方向)。
  • 优点:
  • 易于使用:简单直接,无需额外工具。
  • 动态数组:如果源单元格中的数据发生变化,会自动调整,确保您的输出始终是最新的。

  • 缺点:
  • 可用性有限:仅适用于Excel 365,无法供使用旧版Excel的用户使用。

使用Kutools for Excel将逗号分隔的文本字符串转换为列表

如果您无法使用Excel 365,Kutools for Excel提供了一个强大且直观的替代方案,简化了此任务。通过其“拆分数据到多行”功能,您可以无缝地将逗号分隔的字符串转换为多行,使数据管理更加高效和简便。

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

安装Kutools for Excel后,请按照以下步骤操作:

  1. 点击“Kutools” > “合并与拆分” > “拆分数据到多行”,请参见截图:
    Click Kutools > Merge & Split > Split Data to Rows
  2. 在“拆分数据到多行”对话框中,指定以下操作:
    • 选择要拆分的单元格;
    • 在“分隔依据”部分,选择“其他”,然后输入您的分隔符(例如,逗号和空格),以定义应如何拆分单元格内容;
    • 最后,点击确定按钮。
      specify the options in the dialog box

结果:所选单元格内容已通过逗号拆分为列表。
convert comma separated text string to list with Kutools

📝 注意:此方法直接在源区域拆分数据,因此建议在使用前复制并备份原始数据。
  • 优点:
  • 多功能性:比Excel的原生功能提供更多自定义选项。
  • 用户友好:提供图形界面引导用户完成操作,使不熟悉Excel功能的用户也能轻松上手。
  • 兼容所有Excel版本:Kutools可以在所有Excel版本中使用。

  • 缺点:
  • 需要安装。

使用VBA代码将逗号分隔的文本字符串转换为列表

以下VBA代码可以帮助您将多个逗号分隔的单元格值转换为一列,请按照以下步骤操作:

1. 在Excel中按住“Alt + F11”键,打开“Microsoft Visual Basic for Applications”窗口。

2. 点击“插入” > “模块”,并将以下宏粘贴到模块窗口中。

VBA代码:将逗号分隔的文本字符串转换为行或列表

Sub RedistributeCommaDelimitedData()
'Updateby Extendoffice
    Dim xArr() As String
    Dim xAddress As String
    Dim Rg As Range
    Dim Rg1 As Range
    On Error Resume Next
    xAddress = Application.ActiveWindow.RangeSelection.Address
    Set Rg = Application.InputBox("please select the data range:", "Kutools for Excel", xAddress, , , , , 8)
    If Rg Is Nothing Then Exit Sub
    Set Rg = Application.Intersect(Rg, Rg.Parent.UsedRange)
    If Rg Is Nothing Then Exit Sub
    Set Rg1 = Application.InputBox("please select output cell:", "Kutools for Excel", , , , , , 8)
    If Rg1 Is Nothing Then Exit Sub
    xArr = Split(Join(Application.Transpose(Rg.Value), ","), ",")
    Rg1.Resize(UBound(xArr) + 1) = Application.Transpose(xArr)
    Rg1.Parent.Activate
    Rg1.Resize(UBound(xArr) + 1).Select
End Sub

3. 然后按F5键运行此代码,在弹出的对话框中,选择要转换的数据范围,请参见截图:

run vba code to select the data list

4. 点击确定,在接下来的对话框中,指定要输出结果的单元格,请参见截图:

specify a cell to output the result

5. 点击确定按钮,所选逗号分隔的单元格值已被转换为行列表。请参见截图:

the selected comma separated cell values have been converted into a list

  • 优点:
  • 兼容所有Excel版本:VBA可以在Excel 2007及更高版本中使用。
  • 自动化处理:能够批量处理大量数据,非常适合重复性任务。

  • 缺点:
  • 需要编程知识:VBA代码需要一定的编程专业知识,对初学者可能不够友好。
  • 安全问题:启用宏可能存在安全风险,尤其是在处理来自未知来源的文件时。

无论您更喜欢像Kutools这样的无代码解决方案、Excel 365内置公式的简洁性,还是VBA脚本的强大功能,Excel都提供了各种工具来高效地将逗号分隔的文本字符串转换为可用的数据格式。这些方法提高了生产力,并允许在电子表格中进行更有效的数据管理和分析。如果您有兴趣探索更多Excel技巧,我们的网站提供了数千个教程,帮助您掌握Excel


相关文章:

如何通过回车符将单元格拆分为多列或多行?

如何在Excel中将单元格值拆分为多列?


最佳 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%,每天帮你减少上百次鼠标点击!