跳到主要内容

如何在Excel中查找字符的第一个,最后一个或第n个出现?

作者:晓阳 最后修改时间:2020-05-26

假设您具有以下包含字符“-”的文本字符串列表,并且现在想要获取字符“-”的最后或第n个出现,您是否有解决此问题的好主意?


用公式查找字符的最后一次出现

这里有一些公式可以帮助您找到特定字符的最后位置,请执行以下操作:

1。 在您的文字字符串旁边,请输入以下任一公式或将其复制到空白单元格中:

=SEARCH("^^",SUBSTITUTE(A2,"-","^^",LEN(A2)-LEN(SUBSTITUTE(A2,"-",""))))
=LOOKUP(2,1/(MID(A2,ROW(INDIRECT("1:"&LEN(A2))),1)="-"),ROW(INDIRECT("1:"&LEN(A2))))

2。 然后将填充手柄拖到您要应用此公式的范围内,您将获得最后一次出现的特定字符“-”,请参见屏幕截图:

请注意: 在上述公式中, A2 指示您要使用的单元格值。 还有“-”代表您要获得其最后位置的特定字符,您可以根据需要将其更改为任何其他字符。


使用用户定义函数查找字符的最后一次出现

要获取最后一个字符“-”的位置,您还可以创建用户定义函数,方法如下:

1。 打开您要使用的工作表。

2。 按住 ALT + F11 键打开 Microsoft Visual Basic应用程序窗口.

3。 然后点击 插页 > 模块,然后将以下宏粘贴到 模块窗口.

VBA代码:查找字符的最后一次出现

Function LastpositionOfChar(strVal As String, strChar As String) As Long
LastpositionOfChar = InStrRev(strVal, strChar)
End Function

4。 然后保存并关闭此代码,返回到工作表,然后输入此公式 = lastpositionofchar(A2,“-”) 除数据之外,将其插入空白单元格,请参见屏幕截图:

5。 然后将填充手柄拖动到应用此公式所需的范围,并且从文本字符串中提取了最后一个字符“-”的出现,如下屏幕截图所示:

备注:在上式中: A2 是包含您要使用的数据的单元格,并且“-”是您需要找到其最后位置的字符,您可以根据需要对其进行修改。


用公式查找字符的第一个或第n个出现

要获得特定角色的第一个或第n个位置,请应用以下公式:

1。 将以下公式输入或复制到要放入结果的空白单元格中,然后按 输入 获得第一个结果的关键:

=FIND(CHAR(160),SUBSTITUTE(A2,"-",CHAR(160),2))

2。 然后,将填充手柄向下拖动到要应用此公式的单元格上,并且已经计算出第二个“-”字符的位置,请参见屏幕截图:

请注意: 在上述公式中, A2 表示您要使用的单元格值,“-”代表您要获取其位置的特定字符,数字 2 代表要获取的字符的指定出现位置。


通过简单的功能查找特定字符的第一个或第n个出现

Kutools for Excel查找字符在字符串中第N个出现的位置 实用程序,您可以快速,轻松地获得第一个或第n个特定字符的位置。

请注意:申请这个 查找字符在字符串中第N个出现的位置,首先,您应该下载 Kutools for Excel,然后快速轻松地应用该功能。

安装后 Kutools for Excel,请这样做:

例如,我想第二次出现字符“-”,请执行以下操作:

1。 单击要放置结果的单元格。

2。 然后点击 库工具 > 公式助手 > 公式助手,请参见屏幕截图:

3。 在 公式助手 对话框:

  • 选择 查找 选项从 公式 Type 下拉列表;
  • 然后选择 查找字符在字符串中第N个出现的位置 来自 选择一个草 列表框;
  • 参数输入 部分中,选择包含要使用的文本字符串的单元格,然后输入要获取其位置的字符,最后,指定要获取该字符位置的数字。

4。 然后点击 Ok 按钮,然后将填充手柄向下拖动到要获取位置的单元格,以根据需要获得以下结果。

立即下载和免费试用Excel的Kutools!


更多相关文章:

  • 在Excel中提取除第一个/最后一个单词外的所有内容
  • 要从一个单元格中提取所有单词,但第一个或最后一个单词可以帮助您删除所需的不需要的单词,当然,在这种情况下,您可以复制所需的单词并将它们逐个粘贴到另一个单元格中。 但是,如果除了第一个或最后一个单词之外还需要提取多个单元格值,这将很无聊。 您如何快速,轻松地提取Excel中除第一个或最后一个单词以外的所有单词?
  • 提取单元格中从右到左的字符
  • 本文将讨论从右边的单元格中拉出或提取字符,直到到达空格以在Excel工作表中获得以下结果为止。 本文中的一个有用公式可以快速轻松地解决此问题。
  • 查找第一个小写字母的位置
  • 现在,如果您有一个包含大写和小写字母的文本字符串列表,现在,您想知道第一个小写字母在Excel工作表中的位置。 您如何快速获得结果而又不一一列举呢?

最佳办公生产力工具

🤖 Kutools 人工智能助手:基于以下内容彻底改变数据分析: 智能执行   |  生成代码  |  创建自定义公式  |  分析数据并生成图表  |  调用 Kutools 函数...
热门特色: 查找、突出显示或识别重复项   |  删除空白行   |  合并列或单元格而不丢失数据   |   不使用公式进行四舍五入 ...
超级查询: 多条件VLookup    多值VLookup  |   跨多个工作表的 VLookup   |   模糊查询 ....
高级下拉列表: 快速创建下拉列表   |  依赖下拉列表   |  多选下拉列表 ....
列管理器: 添加特定数量的列  |  移动列  |  切换隐藏列的可见性状态  |  比较范围和列 ...
特色功能: 网格焦点   |  设计图   |   大方程式酒吧    工作簿和工作表管理器   |  资源库 (自动文本)   |  日期选择器   |  合并工作表   |  加密/解密单元格    按列表发送电子邮件   |  超级筛选   |   特殊过滤器 (过滤粗体/斜体/删除线...)...
前 15 个工具集12 文本 工具 (添加文本, 删除字符,...)   |   50+ 图表 类型 (甘特图,...)   |   40+ 实用 公式 (根据生日计算年龄,...)   |   19 插入 工具 (插入二维码, 从路径插入图片,...)   |   12 转化 工具 (小写金额转大写, 货币兑换,...)   |   7 合并与拆分 工具 (高级组合行, 分裂细胞,...)   |   ... 和更多

使用 Kutools for Excel 增强您的 Excel 技能,体验前所未有的效率。 Kutools for Excel 提供了 300 多种高级功能来提高生产力并节省时间。  单击此处获取您最需要的功能...

描述


Office Tab 为 Office 带来选项卡式界面,让您的工作更加轻松

  • 在Word,Excel,PowerPoint中启用选项卡式编辑和阅读,发布者,Access,Visio和Project。
  • 在同一窗口的新选项卡中而不是在新窗口中打开并创建多个文档。
  • 每天将您的工作效率提高50%,并减少数百次鼠标单击!
Comments (3)
No ratings yet. Be the first to rate!
This comment was minimized by the moderator on the site
Using LET to define variables. 
Find Last occurrence of;
=LET(strFind,"-",strFlag,"¤",FIND(strFlag,SUBSTITUTE(A2,strFind,strFlag,LEN(A2)-LEN(SUBSTITUTE(A2,strFind,""))),1))
Text to right of;
LET(strTarget,A2,strFind,"-",strFlag,"¤",RIGHT(strTarget,LEN(strTarget)-FIND(strFlag,SUBSTITUTE(strTarget,strFind,strFlag,LEN(strTarget)-LEN(SUBSTITUTE(strTarget,strFind,""))),1)))
This gives an error if strFind is not in the target. This can be solved by wrapping FIND in an IFERROR. 
LET(strTarget,A2,strFind,"-",strFlag,"¤",IFERROR(FIND(strFlag,SUBSTITUTE(strTarget,strFind,strFlag,LEN(strTarget)-LEN(SUBSTITUTE(strTarget,strFind,""))),1),0))
LET(strTarget,A2,strFind,"-",strFlag,"¤",RIGHT(strTarget,LEN(strTarget)-IFERROR(FIND(strFlag,SUBSTITUTE(strTarget,strFind,strFlag,LEN(strTarget)-LEN(SUBSTITUTE(strTarget,strFind,""))),1),0)))
This will return the existing string if strFind is not found. If this is not desired use the find separately then test for result>0.
This comment was minimized by the moderator on the site
Thank You, great work !! Best Regards Anders
This comment was minimized by the moderator on the site
Thank you for these formulas. Very helpful.
There are no comments posted here yet
Leave your comments
Posting as Guest
×
Rate this post:
0   Characters
Suggested Locations