FILTERXML函数,用过没?

yumo6663个月前 (05-21)技术文章11

今天给大家聊一个比较陌生的函数:FILTERXML

语法格式:FILTERXML(xml, xpath)

这个函数有两个必需的参数,第1参数是有效的xml格式的字符串,第2参数是指定的xpath。

正常而言,该函数常用于解析xml结构的网页数据。但不正常的是……咱们可以人为搭建xml格式的字符串,进而实现原本很复杂的文本处理问题。

举个例子。

以上图所示的数据为例,需要按分隔符拆分。

参考函数如下:

C2单元格输入公式后横/纵向填充

=IFERROR(INDEX(FILTERXML("<a><b>"&SUBSTITUTE($A2,"-","</b><b>")&"</b></a>","a/b"),COLUMN(A1)),"")

有朋友可能会觉得这个问题更适合使用基础技巧:分列

基础技巧和函数的优劣区别咱们说过很多次了,函数的优势有两个,一个是可以搭建结果和数据源之间的关联,当数据源发生了变动,计算结果可以自动更新,另外一个是函数的计算结果可以嵌套在另外一个函数中继续使用,比如说……

现在需要获取A列中的数值,并按从小到大排序。

参考函数如下:

C2单元格输入公式后横/纵向填充

=IFERROR(SMALL(FILTERXML("<a><b>"&SUBSTITUTE($A2,"-","</b><b>")&"</b></a>","a/b"),COLUMN(A1)),"")

再比如说,统计下图所示A列数据中不重复的人名数:

参考函数如下:

B2单元格输入公式后向下复制填充

=COUNTA(FILTERXML("<a><b>"&SUBSTITUTE($A2,"-","</b><b>")&"</b></a>","a/b[not(following::*=.)]"))


又或者,将A列不重复的人名拆分:

参考函数如下:

C2单元格输入公式后横/纵向填充

=IFERROR(INDEX(FILTERXML("<a><b>"&SUBSTITUTE($A2,"-","</b><b>")&"</b></a>","a/b[not(following::*=.)]"),COLUMN(A1)),"")

……

以上函数解法中都使用到了FILTERXML函数,下面稍微解释一下它,大家就多少了解一下。坦白的说,这些都是套路,理不理解并不重要,重要的是遇到同类问题会套用。

以下部分是FILTERXML函数的第1参数:

"<a><b>"&SUBSTITUTE($A2,"-","</b><b>")&"</b></a>"

SUBSTITUTE函数将A2单元格的分隔符,替换为</b><b>,最后返回一个xml结构的字符串。

<a>
<b>看见星光</b>
<b>随风小妞</b>
<b>看见星光</b>
</a>

至于啥是xml……感兴趣的朋友可以搜狗。

简单而言,它是一种可扩展标记语言,有标签组成节点,标签必须按合适的顺序进行嵌套,任何的起始标签都必须有一个结束标签。

以上文为例,<a>是开始标签,</a>是结束标签。b是嵌套在a节点内的子节点。

如果我们需要获取a节点下所有b节点的内容,可以将FILTERXML函数第2参数的xpath设置为:

a/b

此时FILTERXML函数返回一个纵向一维内存数组。

{"看见星光";"随风小妞";"看见星光"}

如果在获取a节点下所有b节点文本内容的同时去重复,可以将FILTERXML函数第2参数的xpath设置为:

a/b[not(following::*=.)]

最后,再在FILTERXML函数外嵌套其它查询/聚合/容错函数,即可返回指定结果。

……

挥挥手,下期再见。

图文制作:看见星光

原载:Excel星球

相关文章

Vlookup过时,新函数公式Filter,太牛了

在新版本的Excel里面,更新了一个Filter新函数公式, 在日常工作中,用途广泛,甚至可以动摇vlookup大哥的身份1、基本用法介绍Filter公式是筛选函数,使用用法,就像你在对数据筛选,把筛...

不支持自动溢出,函数FILTER仍然好用,无论Excel还是WPS

之前两篇关于函数的FILTER的文章备受关注,说明这个函数确实能给大家的工作带来便利。点击查看第一篇点击查看第二篇同时也有不少吐槽,在没有溢出功能的WPS中其效果大打折扣。没有自动溢出,我们就来手动溢...

简称查找全称,Vlookup,Xlookup,Filter哪个公式更厉害

举个工作实例,左边是员工数据表,需要根据员工的简称,快速查找匹配出对应工资数据。今天分享热门的3个公式大PK,看你更喜欢用哪个1、Vlookup函数公式我们需要搭配通配符来查找匹配,通配符*,表示任意...

传统筛选点到手抽筋?FILTER函数让你体验开挂式办公!

“领导突然要南京和浙江的客户的销量!”如图所示:你是不是还在用传统方法筛选数据?1 按Ctrl+Shift+L 调出筛选按钮2 在下拉菜单里选择文本筛选3 在弹窗里手动输入“南京”或“浙江”4 把结果...

Filter函数的三种用法,比用VLOOKUP一对多查询,更加灵活方便

文章最后有彩蛋!好礼相送!Excel秘籍大全,正文开始FILTER 函数可以基于定义的条件筛选一系列数据。在没有filter函数之前,如果实现一对多查询,常见的是构建辅助列,然后使用VLOOKUP+R...

跳过VLOOKUP天坑!FILTER函数10个招式让同事以为你开了外挂?

还在为VLOOKUP的"一对多"限制头疼?是否还在为INDEX+MATCH的嵌套抓狂?今天教你用Excel新晋顶流——FILTER函数,10个高能用法让你秒变数据操控大师!用法1:精准...