I.此XPath 2.0表达式:
substring-after(tokenize($pUrl, '[?|&]')[starts-with(., 'v=')], 'v=')
产生想要的,正确的结果。
或者,可以使用稍短:
tokenize(tokenize($pUrl, '[?|&]')[starts-with(., 'v=')], '=')[2]
下面是一个完整XSLT 2.0转化:
<xsl:stylesheet version="2.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="text"/>
<xsl:param name="pUrl" select=
"'http://www.youtube.com/watch?v=qadqO3TOvbQ&feature=channel&list=UL'"/>
<xsl:template match="/">
<xsl:sequence select=
"tokenize(tokenize($pUrl, '[?|&]')[starts-with(., 'v=')], '=')[2]"/>
</xsl:template>
</xsl:stylesheet>
当这种转化是在任何XML文档应用(未使用),产生想要的正确结果:
qadqO3TOvbQ
二,此XPath 1.0表达式:
concat
(substring-before(substring-after(concat($pUrl,'&'),'?v='),'&'),
substring-before(substring-after(concat($pUrl,'&'),'&v='),'&')
)
产生想要的结果。
请注意:
两种解决方案都提取期望字符串即使命名v
查询字符串参数不是第一个,甚至在情况下,当它是最后一个。
问题是我不知道它是否会以功能结束...用户只会复制网址并期望它能够正常工作。我的工作是解析一切。我在考虑?v =和&,但它可能没有&符号。 – Armstrongest 2012-07-11 16:42:20
好的...对于xmlplayground ...完全+1网站。此外,我修改了解决方案'\t 也要抓住正确的URL。 –
Armstrongest
2012-07-11 16:47:10
谢谢 - 我几周前推出了它。传播达字:)很高兴你得到了你需要的结果。 – Utkanos 2012-07-11 16:57:30