前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Excel实战技巧103:使用FILTERXML()通过位置提取单词

Excel实战技巧103:使用FILTERXML()通过位置提取单词

作者头像
fanjy
发布2021-06-01 11:10:27
2.3K0
发布2021-06-01 11:10:27
举报
文章被收录于专栏:完美Excel

本文介绍FILTERXML函数的一个奇特用法。

假设在单元格中有一些文本(句子/短语/关键字,等),你想要提取其中的第n个单词,然而Excel并没有SPLIT函数,那就需要编写复杂的数组公式或者使用辅助列或者使用VBA。

可以使用FILTERXML函数来实现。

示例如下图1,在单元格C3中放置了要从中提取单词的句子,在单元格C7中输入要提取的单词序号后,单元格C8中将显示相应的单词。

图1

步骤1:将句子转换成有效的XML

虽然看起来复杂,但其实很简单,需要做的是插入一些标签,像下面这样:

="<DATA><A>"& SUBSTITUTE(C3, " ","</A><A>") & "</A></DATA>"

这将把单元格C3中的内容转换成有效的XML块,其每个单词作为<A>节点。

步骤2:使用FILTERXML提取单词

有了有效的XML之后,可以使用:

=FILTERXML(C5, “/DATA/A[3]”)

从转换的XML语句中提取第三个单词。

将公式中的硬编码使用输入数字的单元格代替,公式如单元格C10所示。

技巧提示:使用[last()]获取最后一个单词。例如,公式

=FILTERXML(C5, “/DATA/A[last()]”)

将获取句子中的最后一个单词。

注:本文整理自chandoo.org,供有兴趣的朋友学习参考。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-05-11,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 完美Excel 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档