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?
可以将文章内容翻译成中文,广告屏蔽插件可能会导致该功能失效(如失效,请关闭广告屏蔽插件后再试):
问题:
回答1:
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:
- Declare the Woot namespace
http://www.woot.com/
so that when you use that namespace prefix in your XPATH it will be understood. - Use a more generic XPATH statement that uses predicate filters that use
local-name()
andnamespace-uri()
to match the element.//rss/channel/item/*[local-name()='price' and namespace-uri()='http://www.woot.com/']