Excel实战技巧103:使用FILTERXML()通过位置提取单词
excelperfect
本文介绍FILTERXML函数的一个奇特用法。
假设在单元格中有一些文本(句子/短语/关键字,等),你想要提取其中的第n个单词,然而Excel并没有SPLIT函数,那就需要编写复杂的数组公式或者使用辅助列或者使用VBA。
可以使用FILTERXML函数来实现。
示例如下图1,在单元格C3中放置了要从中提取单词的句子,在单元格C7中输入要提取的单词序号后,单元格C8中将显示相应的单词。
图1
步骤1:将句子转换成有效的XML
虽然看起来复杂,但其实很简单,需要做的是插入一些标签,像下面这样:
这将把单元格C3中的内容转换成有效的XML块,其每个单词作为<A>节点。
步骤2:使用FILTERXML提取单词
有了有效的XML之后,可以使用:
=FILTERXML(C5, “/DATA/A[3]”)
从转换的XML语句中提取第三个单词。
将公式中的硬编码使用输入数字的单元格代替,公式如单元格C10所示。
技巧提示:使用[last()]获取最后一个单词。例如,公式
将获取句子中的最后一个单词。
注:本文整理自chandoo.org,供有兴趣的朋友学习参考。
赞 (0)