獲取文本
表達式描述a/text()獲取 a 下的文本a//text()獲取 a 下所有元素的文本//a[text()='下一頁']獲取文本為下一頁的 a 元素獲取屬性
表達式描述nodename選取此節點的所有子節點/從當前節點選取直接子節點//從當前節點選取子孫節點.選取當前節點..選取當前節點的父節點@選取屬性*匹配任何元素節點@*匹配任何屬性節點node()匹配任何類型的節點1.3示例from lxml import etree
text = ''' <div> <ul>
<li><a href="link1.html">first item</a></li>
<li><a href="link2.html">second item</a></li>
<li><a href="link3.html">third item</a></li>
<li><a href="link4.html">fourth item</a></li>
<li><a href="link5.html">fifth item</a>
</ul> </div> '''
html = etree.HTML(text)
print(html) # <Element html at 0x1f1007c9d08>
print(etree.tostring(html).decode())
# 獲取 class 為 item-1 li 下的 a 的 href
ret1 = html.xpath('//li[@class="item-1"]/a/@href')
print(ret1)
# 獲取 class 為 item-1 li 下的文本
ret2 = html.xpath("//li[@class='item-1']/a/text()")
print(ret2)
# 把 url 和 文本組成字典
# 如果其中一個獲取失敗或者沒有數據,則url 和 title 就不是原來對應的結果
for i in ret1:
item = {}
item['url'] = i
item['title'] = ret2[ret1.index(i)]
print(item)
# 改進
ret3 = html.xpath('//li[@class="item-1"]')
for i in ret3:
item = {}
item['url'] = i.xpath('./a/@href')[0] if len(i.xpath('./a/@href')) else None # ./a/@href 表示當前節點下的
item['title'] = i.xpath('./a/text()')[0] if len(i.xpath('./a/text()')) else None
print(item)
聲明:https://juejin.cn/post/6844903764302757895