跳至主要内容

在Excel列表中翻转或颠倒名字和姓氏的位置

Author: Xiaoyang Last Modified: 2025-07-31

如果你有一个全名列表,格式为姓氏和名字,现在你想将姓氏和名字的位置翻转为如下截图所示。本文将介绍一些在Excel中处理此任务的公式。

doc-flip-first-last-name-1


翻转或颠倒名字和姓氏的位置(Stone Jerry = Jerry Stone)

通常,在Excel中,结合SEARCH和LEN函数使用的MID函数可以帮助你按需翻转名字和姓氏的顺序。

如果全名格式为“姓 名”,要颠倒名字和姓氏的顺序,请在需要显示结果的空白单元格中输入以下公式:

=MID(A2&" "&A2,SEARCH(" ",A2)+1,LEN(A2))

然后,向下拖动填充柄以应用该公式到其他单元格,所有名字和姓氏都会如下面截图所示被颠倒:

doc-flip-first-last-name-2


公式解释:

A2&" "&A2: 这部分用于连接A2单元格的内容,并用空格分隔合并后的数据,得到的结果是:“Stone Jerry Stone Jerry”,这在MID函数中被识别为文本参数。

SEARCH(" ",A2)+1: SEARCH函数用于查找A2单元格中空格字符的位置,加1表示获取空格后第一个字符的位置。这部分在MID函数中被识别为start_num参数。

LEN(A2): 此LEN函数返回A2单元格中文本的长度,它在MID函数中被识别为num_chars参数。

MID(A2&" "&A2,SEARCH(" ",A2)+1,LEN(A2)): 到目前为止,MID函数用于从“Stone Jerry Stone Jerry”中提取文本,起始位置由SEARCH函数返回,长度由LEN函数返回。


翻转或颠倒带逗号的名字和姓氏(Stone, Jerry = Jerry Stone)

假设你的姓氏和名字之间用逗号分隔,现在你想颠倒姓氏和名字的顺序并跳过逗号,如下截图所示,如何在Excel中解决这个任务呢?

doc-flip-first-last-name-3

请复制或在空白单元格中输入以下公式:

=MID(A2&" "&A2,SEARCH(",",A2)+2,LEN(A2)-1)

然后,向下拖动填充柄以应用该公式到其他单元格,你会得到所需的结果,见截图:

doc-flip-first-last-name-4


公式解释:

A2&" "&A2: 这部分用于连接A2单元格的内容,并用空格分隔合并后的数据,得到的结果是:“Stone, Jerry Stone, Jerry”,这在MID函数中被识别为文本参数。

SEARCH(",",A2)+2: SEARCH函数用于查找A2单元格中逗号字符的位置,加2表示获取逗号后第一个字符的位置。这部分在MID函数中被识别为start_num参数。

LEN(A2)-1: 此LEN函数返回A2单元格中文本的长度,减去1表示排除逗号,它在MID函数中被识别为num_chars参数。

MID(A2&" "&A2,SEARCH(",",A2)+2,LEN(A2)-1): 到目前为止,MID函数用于从“Stone, Jerry Stone, Jerry”中提取文本,起始位置由SEARCH函数返回,长度由LEN函数返回。


翻转或颠倒不带逗号的名字和姓氏(Stone Jerry = Jerry, Stone)

要翻转由空格分隔的名字和姓氏,在翻转名字后,你还希望在名字后面添加逗号,如下截图所示。为了解决这个问题,这里还有另一个公式可以帮助你。

doc-flip-first-last-name-5

请复制或在空白单元格中输入以下公式:

=MID(A2&", "&A2,SEARCH(" ",A2)+1,LEN(A2)+1)

然后,向下拖动填充柄以将公式复制到你需要的其他单元格,名字已被颠倒,且在名字后插入了逗号,见截图:

doc-flip-first-last-name-6


公式解释:

A2&", "&A2: 这部分用于连接A2单元格的内容,并用逗号和空格分隔合并后的数据,得到的结果是:“Stone Jerry, Stone Jerry”,这在MID函数中被识别为文本参数。

SEARCH(" ",A2)+1: SEARCH函数用于查找A2单元格中空格字符的位置,加1表示获取空格后第一个字符的位置。这部分在MID函数中被识别为start_num参数。

LEN(A2)+1: 此LEN函数返回A2单元格中文本的长度,加1表示包含逗号,它在MID函数中被识别为num_chars参数。

MID(A2&", "&A2,SEARCH(" ",A2)+1,LEN(A2)+1): 到目前为止,MID函数用于从“Stone Jerry, Stone Jerry”中提取文本,起始位置由SEARCH函数返回,长度由LEN函数返回。


提示:

1. 如果你的全名包含名字、中间名和姓氏,要颠倒这些名字,你应该使用以下公式:

=MID(TRIM(A2)&" "&TRIM(A2),IF(LEN(TRIM(A2))-LEN(SUBSTITUTE(TRIM(A2)," ",""))=1,FIND(" ",TRIM(A2))+1,FIND(" ",TRIM(A2),FIND(" ",TRIM(A2))+1)+1),LEN(TRIM(A2)))

doc-flip-first-last-name-7

2. 要在颠倒后的姓氏和名字之间添加逗号,请使用以下公式:

=MID(TRIM(A2)&", "&TRIM(A2),IF(LEN(TRIM(A2))-LEN(SUBSTITUTE(TRIM(A2)," ",""))=1,FIND(" ",TRIM(A2))+1,FIND(" ",TRIM(A2),FIND(" ",TRIM(A2))+1)+1),LEN(TRIM(A2))+1)

doc-flip-first-last-name-8


根据任意分隔符翻转或颠倒名字和姓氏顺序的强大功能

Kutools for Excel 提供了一个便捷的工具——反转文本功能,可以根据空格、逗号或任何其他分隔符来帮助你反转单元格内的文本字符串顺序。 点击下载 Kutools for Excel 免费试用!


相关函数:

  • MID:
  • MID 函数用于从给定文本字符串的中间查找并返回特定数量的字符。
  • SEARCH:
  • 在 Excel 中,SEARCH 函数可帮助你从给定的文本字符串中查找特定字符或子字符串的位置。
  • LEN:
  • LEN 函数返回文本字符串中的字符数。

更多文章:

  • 从全名中提取名字首字母和姓氏
  • 假设你有一个全名列表,现在你想要从全名中提取名字的首字母和姓氏,或者名字和姓氏的首字母,如下截图所示。如何在Excel工作簿中处理这些任务呢?
  • 从单元格中提取多行文本
  • 如果你有一系列通过换行符分隔的文本字符串(在输入文本时按下Alt + Enter键产生的),现在你想将这些文本行提取到多个单元格中,如下截图所示。如何在Excel中用公式解决这个问题呢?
  • 从文本字符串中提取括号内的文本
  • 如果文本字符串中有部分文本被括号包围,现在你需要提取括号内的所有文本字符串,如下截图所示。如何快速轻松地在Excel中解决这个任务呢?

最佳的办公生产力工具

Kutools for Excel - 助您脱颖而出

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

Kutools for Excel 拥有超过 300 项功能,确保您所需的一切都仅需一键之遥...


Office Tab - 在 Microsoft Office(包括 Excel)中启用标签式阅读和编辑

  • 一秒内在数十个打开的文档之间切换!
  • 每天为您减少数百次鼠标点击,告别鼠标手。
  • 在查看和编辑多个文档时,您的生产力可提升 50%。
  • 为 Office(包括 Excel)带来高效标签页,就像 Chrome、Edge 和 Firefox 一样。