首页 > 其他 > 详细

爬虫x_path

时间:2019-11-27 21:41:09      阅读:51      评论:0      收藏:0      [点我收藏+]
doc=‘‘‘
<html>
 <head>
  <base href=‘http://example.com/‘ />
  <title>Example website</title>
 </head>
 <body>
  <div id=‘images‘>
   <a href=‘image1.html‘ a="xxx">Name: My image 1 <br /><img src=‘image1_thumb.jpg‘ /></a>
   <a href=‘image2.html‘>Name: My image 2 <br /><img src=‘image2_thumb.jpg‘ /></a>
   <a href=‘image3.html‘>Name: My image 3 <br /><img src=‘image3_thumb.jpg‘ /></a>
   <a href=‘image4.html‘ class=‘li‘>Name: My image 4 <br /><img src=‘image4_thumb.jpg‘ /></a>
   <a href=‘image5.html‘ class=‘li li-item‘ name=‘items‘>Name: My image 5 <br /><img src=‘image5_thumb.jpg‘ /></a>
   <a href=‘image6.html‘ name=‘items‘><span><h5>test</h5></span>Name: My image 6 <br /><img src=‘image6_thumb.jpg‘ /></a>
  </div>
 </body>
</html>
‘‘‘
from lxml import etree

html=etree.HTML(doc)
# html=etree.parse(‘search.html‘,etree.HTMLParser())
# 1 所有节点
a=html.xpath(//*)    #匹配所有标签
# 2 指定节点(结果为列表)
# a=html.xpath(‘//head‘)
# 3 子节点,子孙节点
a=html.xpath(//div/a)
a=html.xpath(//body/a) #无数据
a=html.xpath(//body//a)
# 4 父节点
# a=html.xpath(‘//body//a[@href="image1.html"]/..‘)
a=html.xpath(//body//a[1]/..)  #从1开始
# 也可以这样
a=html.xpath(//body//a[1]/parent::*)
# 5 属性匹配
a=html.xpath(//body//a[@href="image1.html"])

# 6 文本获取
a=html.xpath(//body//a[@href="image1.html"]/text())
a=html.xpath(//body//a/text())

# 7 属性获取
# a=html.xpath(‘//body//a/@href‘)
# # 注意从1 开始取(不是从0)
a=html.xpath(//body//a[2]/@href)
# 8 属性多值匹配
#  a 标签有多个class类,直接匹配就不可以了,需要用contains
# a=html.xpath(‘//body//a[@class="li"]‘)
a=html.xpath(//body//a[contains(@class,"li")]/text())
# a=html.xpath(‘//body//a[contains(@class,"li")]/text()‘)
# 9 多属性匹配
a=html.xpath(//body//a[contains(@class,"li") or @name="items"])
a=html.xpath(//body//a[contains(@class,"li") and @name="items"]/text())
a=html.xpath(//body//a[contains(@class,"li")]/text())
# 10 按序选择
a=html.xpath(//a[2]/text())
a=html.xpath(//a[2]/@href)
# 取最后一个
a=html.xpath(//a[last()]/@href)
# 位置小于3的
a=html.xpath(//a[position()<3]/@href)
# 倒数第二个
a=html.xpath(//a[last()-2]/@href)
# 11 节点轴选择
# ancestor:祖先节点
# 使用了* 获取所有祖先节点
a=html.xpath(//a/ancestor::*)
# # 获取祖先节点中的div
a=html.xpath(//a/ancestor::div)
# attribute:属性值
a=html.xpath(//a[1]/attribute::*)
# child:直接子节点
a=html.xpath(//a[1]/child::*)
# descendant:所有子孙节点
a=html.xpath(//a[6]/descendant::*)
# following:当前节点之后所有节点
a=html.xpath(//a[1]/following::*)
a=html.xpath(//a[1]/following::*[1]/@href)
# following-sibling:当前节点之后同级节点
a=html.xpath(//a[1]/following-sibling::*)
a=html.xpath(//a[1]/following-sibling::a)
a=html.xpath(//a[1]/following-sibling::*[2]/text())
a=html.xpath(//a[1]/following-sibling::*[2]/@href)

print(a)

 

爬虫x_path

原文:https://www.cnblogs.com/yangxinpython/p/11945513.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!