Use XPath to parse element name containing a colon

2020-04-05 06:25发布

So I'm trying to parse some of the WootAPI with XPath. A problem that I'm running into is that a couple of the elements have colons in their name, such as woot:price or woot:condition. Now, trying to use the XPath //rss/channel/item/woot:price won't grab the contents of the element woot:price, because of the colon, I think. What can I do to get it anyway?

标签: xpath
1条回答
SAY GOODBYE
2楼-- · 2020-04-05 07:26

The colons are because the elements have a namespace prefix and are bound to the Woot namespace.

You should read up on XML namespaces and how they affect XPATH and XSLT.

If you want to reference the Woot elements in your XPATH you will either need to:

  1. Declare the Woot namespace http://www.woot.com/ so that when you use that namespace prefix in your XPATH it will be understood.
  2. Use a more generic XPATH statement that uses predicate filters that use local-name() and namespace-uri() to match the element.
    • //rss/channel/item/*[local-name()='price' and namespace-uri()='http://www.woot.com/']
查看更多
登录 后发表回答