ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 3939|回复: 5

[求助] 通过Filterxml函数提取XML节点值,亟请指教!

[复制链接]

TA的精华主题

TA的得分主题

发表于 2018-2-13 16:54 | 显示全部楼层 |阅读模式
本帖最后由 湛盧 于 2018-2-13 17:12 编辑

希望实现:在单元格输入书号ISBN,函数通过豆瓣API返回相应的书名、价格等数据,
考虑用Filterxml函数嵌套Webservice函数,以ISBN=9787511727541为例,
  1. =IFERROR(FILTERXML(WEBSERVICE("http://api.douban.com/book/subject/isbn/9787511727541"), 此处不知如何填写 ,"")
复制代码
但由于该XML的元素属性并非简单的<title>天鹅绒监狱</title>、<price>38元</price>,
而是<db:attribute name="title">天鹅绒监狱</db:attribute><db:attribute name="price">38.00元</db:attribute>形式,

同时,又因为每本书<db:attribute>属性的数量不定,如本书从<db:attribute name="isbn10"><db:attribute name="pubdate">共有10行,有的书没有<db:attribute name="translator">则只有9行,故不能使用ROW依次列出,因此不知该如何填写上述代码。

亟请指教,谢谢!


该XML内容如下:
  1. <entry xmlns="http://www.w3.org/2005/Atom" xmlns:db="http://www.douban.com/xmlns/" xmlns:gd="http://schemas.google.com/g/2005" xmlns:openSearch="http://a9.com/-/spec/opensearchrss/1.0/" xmlns:opensearch="http://a9.com/-/spec/opensearchrss/1.0/">
  2. <id>http://api.douban.com/book/subject/26593670</id>
  3. <title>天鹅绒监狱</title>
  4. <category scheme="http://www.douban.com/2007#kind" term="http://www.douban.com/2007#book"/>
  5. <author>
  6. <name>[匈牙利] 米克洛什·哈拉兹蒂</name>
  7. </author>
  8. <link  rel="self"/>
  9. <link  rel="alternate"/>
  10. <link  rel="image"/>
  11. <link  rel="mobile"/>
  12. <summary>...</summary>
  13. <db:attribute name="isbn10">7511727549</db:attribute>
  14. <db:attribute name="isbn13">9787511727541</db:attribute>
  15. <db:attribute name="title">天鹅绒监狱</db:attribute>
  16. <db:attribute name="pages">161</db:attribute>
  17. <db:attribute name="translator">戴潍娜</db:attribute>
  18. <db:attribute name="author">[匈牙利] 米克洛什·哈拉兹蒂</db:attribute>
  19. <db:attribute name="price">38.00元</db:attribute>
  20. <db:attribute name="publisher">中央编译出版社</db:attribute>
  21. <db:attribute name="binding">平装</db:attribute>
  22. <db:attribute name="pubdate">2015-10-1</db:attribute>
  23. <db:attribute name="author-intro">...</db:attribute>
  24. <db:tag count="461" name="匈牙利"/>
  25. <db:tag count="419" name="极权主义"/>
  26. <db:tag count="294" name="外国文学"/>
  27. <db:tag count="284" name="米克洛什·哈拉兹蒂"/>
  28. <db:tag count="240" name="东欧"/>
  29. <db:tag count="208" name="政治学"/>
  30. <db:tag count="199" name="文学"/>
  31. <db:tag count="170" name="小说"/>
  32. <gd:rating average="8.2" max="10" min="0" numRaters="883"/>
  33. </entry>
复制代码

TA的精华主题

TA的得分主题

 楼主| 发表于 2018-2-13 18:15 | 显示全部楼层

TA的精华主题

TA的得分主题

 楼主| 发表于 2018-2-14 10:28 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2018-2-14 16:37 | 显示全部楼层
  1. =IFERROR(INDEX(FILTERXML(WEBSERVICE("http://api.douban.com/book/subject/isbn/9787511727541"),"//db:attribute"),ROW(A1)),"")
复制代码

输入一个单元格后,下拉。

TA的精华主题

TA的得分主题

发表于 2018-2-14 16:40 | 显示全部楼层
双斜杠,读取子节点
"//db:attribute"
  1. =IFERROR(INDEX(FILTERXML(WEBSERVICE(),"//db:attribute"),ROW(A1)),"")
复制代码

TA的精华主题

TA的得分主题

 楼主| 发表于 2018-2-18 17:32 | 显示全部楼层
本帖最后由 湛盧 于 2018-2-18 18:01 编辑
wangg913 发表于 2018-2-14 16:40
双斜杠,读取子节点
"//db:attribute"

十分感谢!我原本用的就是ROW(A1),但我的问题也正在此,这么做其实是把每本书的子节点的内容按顺序一一列出,但问题是并非每本书的子节点数量和顺序都是一致的,举例说有一本书有书名、作者、译者,价钱,我这样可以列出这四个内容,与表头的书名作者译者价钱一一对应;另一本书只有书名、作者和价钱,没有译者,那我这么做就会导致这本书的价钱对应到译者的表头上。

总而言之,我希望能每个单元格读取我想要的内容,而不是单纯地按顺序全部列出来,烦请解答!
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-11-16 09:46 , Processed in 0.043395 second(s), 9 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表