爬虫--XPATH解析
今天说一下关于爬取数据解析的方式---->XPATH,XPATH是解析方式中最重要的一种方式
1.安装:pip install lxml
2.原理
1. 获取页面源码数据
2.实例化一个etree的对象,并且将页面源码数据加载到该对象中
3.调用该对象的xpath方法进行指定标签的定位
4.注意:xpath函数必须结合着xpath表达式进行标签定位和内容捕获
说了也不明白,直接上例子!!!!
1.解析58二手房的相关数据
#引用requests
import requests
#引用lxml
from lxml import etree
#地址
url = 'https://bj.58.com/ershoufang/sub/l16/s2242/?utm_source=market&spm=u-2d2yxv86y3v43nkddh1.bdpcpz_bt&PGTID=0d30000c-0000-1139-b00c-643d0d315a04&ClickID=1'
#伪装的请求头,证明我是浏览器
headers = {
'User-Agent':'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.77 Safari/537.36'
}
#获取当前整个页面
page_text = requests.get(url,headers=headers).text
#作用于当前页面之后再解析数据
tree = etree.HTML(page_text)
#//ul[@class="house-list-wrap"]/li这就是lxml解析,//代表前面的层次
li_list = tree.xpath('//ul[@class="house-list-wrap"]/li')
# print(li_list)#得到每一个<Element li at 0x202a8c62288>这玩意
#再次循环
for li in li_list:
#再次解析得到准确的数据!!!
title = li.xpath('./div[2]/h2[1]/a/text()')[0]
print(title)
2.福利福利!!!!下载彼岸图网中的图片数据
import os
import requests
from lxml import etree
#这里注意,这是python3中的写法!!!
import urllib.request
url = 'http://pic.netbian.com/4kmeinv/'
headers = {
'User-Agent':'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.77 Safari/537.36'
}
#二话不说直接发情再说
response = requests.get(url,headers=headers) #如果当前根目录下没有imgs文件夹,就创建!!!
if not os.path.exists('./imgs'):
os.mkdir('./imgs') #得到请求数据
page_text = response.text
#作用当前页面
tree = etree.HTML(page_text)
#lxml解析
li_list = tree.xpath('//div[@class="slist"]/ul/li')
#循环得到准确的数据
for li in li_list:
img_name = li.xpath('./a/b/text()')[0]
# 处理中文乱码!不要理解记住就ok
img_name = img_name.encode('ISO-8859-1').decode('gbk')
#拼接完整的地址
img_url = 'http://pic.netbian.com' + li.xpath('./a/img/@src')[0]
#图片的名字
img_path = './imgs/' + img_name + '.jpg'
#这里避免打开文件就用urllib直接写入
urllib.request.urlretrieve(url=img_url,filename=img_path)
3.解析所有城市名称(https://www.aqistudy.cn/historydata/)
import requests
from lxml import etree url = 'https://www.aqistudy.cn/historydata/' headers = {
'User-Agent':'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.77 Safari/537.36'
} res = requests.get(url=url, headers=headers).text
tree = etree.HTML(res)
city_list = tree.xpath('//div[@class="bottom"]/ul/li/a/text() | //div[@class="bottom"]/ul/div[2]/li/a/text()') # 逻辑运算符,这里 | 表示或的关系
city = ''.join(city_list)
4.煎蛋网的爬去图片
# 煎蛋网图片
import requests
from lxml import etree
#base对于加魔数据进行解密
import base64
import os
import urllib.request if not os.path.exists('./jiandan'):
os.mkdir('./jiandan') headers = {
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.77 Safari/537.36'
}
url = 'http://jandan.net/ooxx' res1 = requests.get(url, headers=headers).text
tree = etree.HTML(res1) span_list = tree.xpath('//span[@class="img-hash"]/text()')
for span_hash in span_list:
#对于加密数据进行解密,编码是utf-8并且拼接完整的url
img_url = 'http:' + base64.b64decode(span_hash).decode('utf8')
#得到具体的数据
img_data = requests.get(url=img_url, headers=headers).content filepath = './jiandan/' + img_url.split('/')[-1]
urllib.request.urlretrieve(url=img_url, filename=filepath)
print(filepath, '下载完成!') print('over')
5.爬去简历模板
import requests
from lxml import etree
import random
import os headers = {
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.77 Safari/537.36'
} if not os.path.exists('./jianli'):
os.mkdir('./jianli')
#爬去前4页的数据
for i in range(1, 4):
if i == 1:
#第一页数据
url = 'http://sc.chinaz.com/jianli/free.html'
else:
#不是第一页的数据,进行数据的拼接
url = 'http://sc.chinaz.com/jianli/free_%s.html' % (i) response = requests.get(url=url, headers=headers)
#字符编码改一下,否则出现这种问题:æ±èçµåçç®åå è´¹ä¸è½½ 下载完成!
response.encoding = 'utf8' res = response.text tree = etree.HTML(res) a_list = tree.xpath('//a[@class="title_wl"]')
for a in a_list:
name = a.xpath('./text()')[0]
jl_url = a.xpath('./@href')[0] response = requests.get(url=jl_url, headers=headers)
response.encoding = 'utf8'
res1 = response.text
tree = etree.HTML(res1)
download_url_list = tree.xpath('//div[@class="clearfix mt20 downlist"]/ul/li/a/@href')
download_url = random.choice(download_url_list) res3 = requests.get(url=download_url, headers=headers).content filepath = './jianli/' + name + '.rar'
#如果上边是content,写入的时候记得’wb'
with open(filepath, 'wb') as f:
f.write(res3)
print(name, '下载完成!') print('over')
6.站长直接图片下载,图片懒加载
import requests
from lxml import etree
import os
import urllib
import urllib.request if not os.path.exists('./tupian'):
os.mkdir('./tupian') url = 'http://sc.chinaz.com/tupian/' headers = {
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.77 Safari/537.36'
} response = requests.get(url=url, headers=headers)
response.encoding = 'utf8'
res = response.text
tree = etree.HTML(res)
url_list = tree.xpath('//div[@id="container"]/div/div/a/img/@src2') # img标签是伪属性src2,当图片滚动到视野内时变为 src for url in url_list:
filepath = './tupian/' + url.rsplit('/', 1)[-1]
urllib.request.urlretrieve(url, filepath)
print(filepath, '下载完成!') print('over')
爬虫--XPATH解析的更多相关文章
- 【XPath Helper:chrome爬虫网页解析工具 Chrome插件】XPath Helper:chrome爬虫网页解析工具 Chrome插件下载_教程_安装 - 开发者插件 - Chrome插件网
[XPath Helper:chrome爬虫网页解析工具 Chrome插件]XPath Helper:chrome爬虫网页解析工具 Chrome插件下载_教程_安装 - 开发者插件 - Chrome插 ...
- 爬虫系列二(数据清洗--->xpath解析数据)
一 xpath介绍 XPath 是一门在 XML 文档中查找信息的语言.XPath 用于在 XML 文档中通过元素和属性进行导航. XPath 使用路径表达式在 XML 文档中进行导航 XPath 包 ...
- 爬虫的三种解析方式(正则解析, xpath解析, bs4解析)
一 : 正则解析 : 常用正则回顾: 单字符: . : 除换行符以外的所有字符 [] : [aoe] [a-w] 匹配集合中任意一个字符 \d : 数字 [0-9] \D : 非数字 \w : 非数字 ...
- 爬虫——网页解析利器--re & xpath
正则解析模块re re模块使用流程 方法一 r_list=re.findall('正则表达式',html,re.S) 方法二 创建正则编译对象 pattern = re.compile('正则表达式 ...
- python爬虫三大解析库之XPath解析库通俗易懂详讲
目录 使用XPath解析库 @(这里写自定义目录标题) 使用XPath解析库 1.简介 XPath(全称XML Path Languang),即XML路径语言,是一种在XML文档中查找信息的语言. ...
- python爬虫使用xpath解析页面和提取数据
XPath解析页面和提取数据 一.简介 关注公众号"轻松学编程"了解更多. XPath即为XML路径语言,它是一种用来确定XML(标准通用标记语言的子集)文档中某部分位置的语言.X ...
- 爬虫-数据解析-xpath
xpath 解析 模块安装 : pip install lxml xpath的解析原理 实例化一个etree类型的对象,且将页面源码数据加载到该对象中 需要调用该对象的xpath方法结合着不同形式的x ...
- 爬虫——xpath
1.什么是xpath? Xpath,全称XML Path Language,即XML路径语言.它是一门在XML之后查找信息的语言,也同样适用于HTML文档的搜索.在做爬虫的时候,我们用XPath语言来 ...
- Scrapy基础(六)————Scrapy爬取伯乐在线一通过css和xpath解析文章字段
上次我们介绍了scrapy的安装和加入debug的main文件,这次重要介绍创建的爬虫的基本爬取有用信息 通过命令(这篇博文)创建了jobbole这个爬虫,并且生成了jobbole.py这个文件,又写 ...
随机推荐
- HDU 4055 Number String (计数DP)
题意:由数字1到n组成的所有排列中,问满足题目所给的n-1个字符的排列有多少个,如果第i字符是‘I’表示排列中的第i-1个数是小于第i个数的. 如果是‘D’,则反之. 析:dp[i][j] 表示前 i ...
- linux命令の删除文件和文件夹 复制粘贴文件和文件夹
声明:此博文来自百度经验http://jingyan.baidu.com/article/642c9d34dcba80644a46f72d.html,谢谢分享! linux删除目录很简单,很多人还是习 ...
- MVC4 路由解析 同名Controller的解决方案
通常我们在MVC中通过Area建立子站的时候会有 controller名称重复的情况,这是后如何区分路由优先级, 我们知道 在Route对象中存在RouteValueDictionary 类型的Dat ...
- Shapefile点图层转换为Shapefile线图层
在Oracle数据表转换为Shapefile(一)和Oracle数据表转换为Shapefile(二)两篇文章中,分别介绍了两种不同的根据Oracle数据表生成Shapefile点图层的方法.本文在此基 ...
- PMBOK项目管理认知概要
2015年6月,通过努力取得PMP证书,很是欣喜,也是对努力付出的一种奖励吧! 通过学习PMP相关的项目管理的知识,对国外的项目管理技术有更加系统的认知.理解.掌握,熟悉全项目生命周期的管理. 其实对 ...
- Backup--BUFFERSIZE 和BUFFERCOUNT
在备份时,可以通过设置BUFFERSIZE 和BUFFERCOUNT来控制备份的时间和CPU的消耗 使用TF 3605 和 TF 3213 来显示备份使用的 BUFFERCOUNT DBCC TRAC ...
- 适用于Java的嵌入式脚本语言
此文已由作者赵昕授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. fakescript 轻量级嵌入式脚本语言 https://github.com/esrrhs/fakescr ...
- IO模型《五》异步IO
Linux下的asynchronous IO其实用得不多,从内核2.6版本才开始引入.先看一下它的流程: 用户进程发起read操作之后,立刻就可以开始去做其它的事.而另一方面,从kernel的角度,当 ...
- 【OCP|052】iZ0-052最新题库及答案整理-第9题
9.Which is true about the Automatic Diagnostic Repository (ADR)? A) It includes diagnostic data for ...
- less配置
一.sublime text需要下载考拉,然后要 一直打开着: 1.编译工具用koala编译 下载地址:http://koala-app.com/index-zh.html 2.LESS中的注释: 可 ...