XPath与多线程爬虫

xiaoxiao2021-02-28  3

#encoding=utf-8 #在进行网页抓取的时候,分析定位html节点是获取抓取信息的关键,目前我用的是lxml模块(用来分析XML文档结构的,当然也能分析html结构), 利用其lxml.html的xpath对html进行分析,获取抓取信息; #神器XPath的介绍与配置 #首先要说的是XPath数据类型。XPath可分为四种数据类型: # 节点集(node-set) :节点集是通过路径匹配返回的符合条件的一组节点的集合。其它类型的数据不能转换为节点集。 # 布尔值(boolean) :由函数或布尔表达式返回的条件匹配值,与一般语言中的布尔值相同,有true和false两个值。布尔值可以和数值类型、字符串类型相互转换。 # 字符串(string) :字符串即包含一系列字符的集合,XPath中提供了一系列的字符串函数。字符串可与数值类型、布尔值类型的数据相互转换。 # 数值(number) :在XPath中数值为浮点数,可以是双精度64位浮点数。另外包括一些数值的特殊描述,如非数值NaN(Not-a- Number)、正无穷大 infinity、负无穷大-infinity、正负0等等。number的整数值可以通过函数取得,另外,数值也可以和布尔类型、字符串类型相互转换。 #XPath是一种语言,可以在XML文档中查找信息,支持HTML,通过元素和属性进行导航,可以用来提取信息,比正则表达式简单且强大 # 神器XPath的使用 # 神器XPath的特殊使用 # 神器XPath的特殊用法 # Python并行化介绍与演示 # 实战--百度贴吧爬虫 # # import lxml # from lxml import etree # import requests # from requests import get from lxml import etree #定义多行字符串 html = ''' <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>测试-常规用法</title> </head> <body> <div id="content"> <ul id="useful"> <li>这是第一条信息</li> <li>这是第二条信息</li> <li>这是第三条信息</li> </ul> <ul id="useless"> <li>不需要的信息1</li> <li>不需要的信息2</li> <li>不需要的信息3</li> </ul> <div id="url"> <a href="http://www.jikexueyuan.com/">极客学院</a> <a href="http://www.jikexueyuan.com/course/?pageNum=1" title="极客学院课程库">点我打开课程库</a> </div> </div> </body> </html> ''' selector = etree.HTML(html) # #提取文本 # content = selector.xpath('//ul[@id="useful"]/li/text()') # # content = selector.xpath('//div[@id="content"]/ul[@id="useful"]/li/text()') # # content = selector.xpath('//div/ul[@id="useful"]/li/text()') # for each in content: # print each # # #提取属性 # # link = selector.xpath('//a/@href') # # # link = selector.xpath('//div[@id="url"]/a/@href') # # for each in link: # # print each # # # title = selector.xpath('//a/@title') # print title[0]
转载请注明原文地址: https://www.6miu.com/read-2050078.html

最新回复(0)