python etree xpath如何获取div下面所有元素的text
时间: 2024-02-19 12:03:04 浏览: 358
利用xpath提取标签下所有文本
你可以使用XPath表达式 `//div//text()` 来获取 `div` 元素下面所有的文本节点。具体方法如下:
```python
from lxml import etree
# 构建 HTML 解析器
parser = etree.HTMLParser()
# 解析 HTML 文本
html = '''
<div>
<p>Hello, World!</p>
<a href="https://www.example.com">Example Website</a>
<span>Goodbye!</span>
</div>
'''
# 将 HTML 文本转换为 Element 对象
root = etree.fromstring(html, parser)
# 获取 div 元素下面所有的文本节点
texts = root.xpath('//div//text()')
# 输出结果
print(texts)
```
输出结果为:
```
['\n ', 'Hello, World!', '\n ', 'Example Website', '\n ', 'Goodbye!', '\n']
```
其中,`texts` 列表中的每一个元素都是一个文本节点的字符串。如果你想要获取去除空白字符的文本内容,可以使用 `normalize-space()` 函数,例如:
```python
# 获取 div 元素下面所有的文本节点(去除空白字符)
texts = root.xpath('normalize-space(//div)')
```
这样就可以获取到 `div` 元素下面所有的文本内容,去除了空白字符。
阅读全文