python3 解析库lxml学习

 lxml是python的一个解析库,支持HTML和XML的解析,支持XPath解析方式,而且解析效率非常高

XPath,全称XML Path Language,即XML路径语言,它是一门在XML文档中查找信息的语言,它最初是用来搜寻XML文档的,但是它同样适用于HTML文档的搜索

XPath的选择功能十分强大,它提供了非常简明的路径选择表达式,另外,它还提供了超过100个内建函数,用于字符串、数值、时间的匹配以及节点、序列的处理等,几乎所有我们想要定位的节点,都可以用XPath来选择

XPath于1999年11月16日成为W3C标准,它被设计为供XSLT、XPointer以及其他XML解析软件使用,更多的文档可以访问其官方网站:https://www.w3.org/TR/xpath/


参考:http://www.cnblogs.com/zhangxinqi/p/9210211.html


XPath常用规则

表达式描述
nodename选取此节点的所有子节点
/从当前节点选取直接子节点
//从当前节点选取子孙节点
.选取当前节点
..选取当前节点的父节点
@选取属性
*通配符,选择所有元素节点与元素名
@*选取所有属性
[@attrib]选取具有给定属性的所有元素
[@attrib='value']选取给定属性具有给定值的所有元素
[tag]选取所有具有指定元素的直接子节点
[tag='text']选取所有具有指定元素并且文本内容是text节点
XPath中的运算符
运算符描述实例返回值

or

age=19 or age=20如果age等于19或者等于20则返回true反正返回false
andage>19 and age<21如果age等于20则返回true,否则返回false
mod取余5 mod 21
|取两个节点的集合//book | //cd返回所有拥有book和cd元素的节点集合
+6+410
-6-42
*6*424
div除法8 div 42
=等于age=19true
!=不等于age!=19true
<小于age<19true
<=小于或等于age<=19true
>大于age>19true
>= 大于或等于age>=19true

实例:

获取开发语言top20

import urllib.request
from lxml import etree
import copy


class TOP20:

    def __init__(self,url):
        self.Tops = []
        self.url = url
        self.response = self.getresponse()
        self.page = self.getetree()
    #end def

    def getresponse(self):
        return urllib.request.urlopen(self.url)
    #end def

    def getetree(self):
        return etree.HTML(self.response.read(),parser=etree.HTMLParser(encoding='utf-8'))
    #end def

    def gettop20(self):
        results = self.page.xpath('//table[@class="table table-striped table-top20"]/tbody/tr/td/text()')
        DICT = {"2018": '', "2017": "", "language": "", "grade": "", "change": ""}
        for i in range(20):
            DICT["2018"] = results[0]
            DICT["2017"] = results[1]
            DICT["language"] = results[2]
            DICT["grade"] = results[3]
            DICT["change"] = results[4]
            del results[0:5]
            self.Tops.append(copy.deepcopy(DICT))
        #end for
    #end def

    def printtop20(self):
        for top in self.Tops:
            print(top)
        #end for
    #end def
#end class

if __name__=="__main__":
    tops = TOP20("https://www.tiobe.com/tiobe-index/")
    tops.gettop20()
    tops.printtop20()

备案审查(qq.com):

import urllib.request
from bs4 import BeautifulSoup
from lxml import etree
import copy


headers = {'User-Agent':'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/50.0.2661.102 Safari/537.36'}
request  = urllib.request.Request("http://icp.chinaz.com/qq.com",headers=headers)
response = urllib.request.urlopen(request)


page = etree.HTML(response.read(),parser=etree.HTMLParser(encoding='utf-8'))



if page.xpath('//div[@class="Tool-IcpMainCent wrapper02"]/p[@class="tc col-red fz18 YaHei pb20"]/text()'):
    print(page.xpath('//div[@class="Tool-IcpMainCent wrapper02"]/p[@class="tc col-red fz18 YaHei pb20"]/text()'))
else:
    print(page.xpath('//div[@class="Tool-IcpMainCent wrapper02"]/div[@class="pr zI0"]/ul[@id="first"]/li/p/text()'))
    print(page.xpath('//div[@class="Tool-IcpMainCent wrapper02"]/div[@class="pr zI0"]/ul[@id="first"]/li/p/strong/text()'))
    print(page.xpath('//div[@class="Tool-IcpMainCent wrapper02"]/div[@class="pr zI0"]/ul[@id="first"]/li/p/font/text()'))

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值