Art*_*rty 23 python regex xpath lxml
我正在使用这样的结构:
doc = parse(url).getroot()
links = doc.xpath("//a[text()='some text']")
Run Code Online (Sandbox Code Playgroud)
但我需要选择所有包含以"some text"开头的文本的链接,所以我想知道有没有办法在这里使用regexp?在lxml文档中没有找到任何内容
Ste*_*ven 38
您可以这样做(尽管您不需要示例的正则表达式).Lxml支持EXSLT扩展函数的正则表达式.(请参阅XPath类的lxml文档,但它也适用于该xpath()方法)
doc.xpath("//a[re:match(text(), 'some text')]",
namespaces={"re": "http://exslt.org/regular-expressions"})
Run Code Online (Sandbox Code Playgroud)
请注意,您需要提供命名空间映射,以便它知道xpath表达式中的"re"前缀代表什么.
Joh*_*ica 15
您可以使用starts-with()函数:
doc.xpath("//a[starts-with(text(),'some text')]")
Run Code Online (Sandbox Code Playgroud)