如何在lxml xpath中使用正则表达式?

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)