IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Python知识库 -> Xpath模块 -> 正文阅读

[Python知识库]Xpath模块

作者:recommend-item-box type_blog clearfix

环境安装

  • pip install lxml

解析原理:html对象是以树状的形式进行展示

在这里插入图片描述

  1. 实例化一个etree的对象,且将待解析的页面源码数据加载到该对象中
  2. 调用etree对象的xpath方法结合着xpath表达式实现标签的定位和数据提取

实例化etree对象

  • etree.parse(‘filename’):将本地html文档加载到该对象中
  • etree.HTML(‘page_text’):网站获取的页面数据加载到该对象

标签定位

  • 最左侧的==/==:如果xpath表达式最左侧是以/开头的表示一定要从根标签开始定位指定标签
  • 非最左侧的==/==:表示一个层级
  • 非左侧的==//==:表示多个层级
  • 属性定位:tagName[@attrName=‘value’]
  • 索引定位:tag[index]索引是从1开始的

取文本

  • /text():直系文本内容
  • //text():所有文本内容

取属性

  • /@attrName

使用xpath爬取图片名称和图片数据

https://pic.netbian.com/4kdongman/

import os
import pymongo
import requests
from lxml import etree

dirName='images'
if not os.path.exists(dirName):
    os.mkdir(dirName)

client = pymongo.MongoClient(host='localhost', port=27017)
db = client.images
collection = db.pic_netbian_com

url='https://pic.netbian.com/4kdongman/'
headers = {
    'User-Agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_13_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/99.0.3538.77 Safari/537.36'
}

response=requests.get(url=url,headers=headers)
response.encoding='GBK'
html=response.text

#解析图片名称+图片数据
tree=etree.HTML(html)

li_list=tree.xpath('//*[@id="main"]/div[3]/ul/li')

for li in li_list:
    #局部数据解析
        #li的数据类型和tree一样,li也可以调用xpath方法
    title=li.xpath('./a/img/@alt')[0].replace(' ','')+'.jpg'
    img_src='https://pic.netbian.com/'+li.xpath('./a/img/@src')[0]
    img_data=requests.get(url=img_src,headers=headers).content
    imgPath=dirName+'/'+title
    with open(imgPath,'wb') as fp:
        fp.write(img_data)

    data={
        'title':title,
        'src':img_src
    }
    result = collection.insert_one(data)
    print(title,'保存成功')
client.close()

在这里插入图片描述

在这里插入图片描述

需求:要求解析出携带html标签的局部数据?

  • bs4,bs4在实现标签定位的时候返回的就是定位到标签对应的字符数据

xpath表达式如何更加具有通用性?

在xpath表达式中使用管道符进行分割的作用,可以表示管道符左右两侧的子xpath表达式同时生效或者一个生效

import os
import pymongo
import requests
from lxml import etree

headers = {
    'User-Agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_13_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/99.0.3538.77 Safari/537.36'
}

#将https://www.aqistudy.cn/historydata所有的城市名称解析出来
url = 'https://www.aqistudy.cn/historydata'

response = requests.get(url=url, headers=headers)
response.encoding = 'utf-8'
html = response.text

tree = etree.HTML(html)
hot_cities = tree.xpath('//div[@class="bottom"]/ul/li/a/text()')
all_cities = tree.xpath('//div[@class="bottom"]/ul/div[2]/li/a/text()')

print(hot_cities)
print(all_cities)

在这里插入图片描述

通用性

在这里插入图片描述

import os
import pymongo
import requests
from lxml import etree

headers = {
    'User-Agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_13_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/99.0.3538.77 Safari/537.36'
}

url = 'https://www.aqistudy.cn/historydata'

response = requests.get(url=url, headers=headers)
response.encoding = 'utf-8'
html = response.text

tree = etree.HTML(html)
# hot_cities = tree.xpath('//div[@class="bottom"]/ul/li/a/text()')
# all_cities = tree.xpath('//div[@class="bottom"]/ul/div[2]/li/a/text()')
# print(hot_cities)
# print(all_cities)
cc=tree.xpath('//div[@class="bottom"]/ul/li/a/text() | //div[@class="bottom"]/ul/div[2]/li/a/text()')
print(cc)


在这里插入图片描述

反爬策略:懒加载

站长素材:高清图片

伪属性:src2被浏览器划到可视化区域才变化为src

反爬机制:图片懒加载,广泛应用于一些图片的网站中

只有在当图片被显示在浏览器可视化范围之内才会将img的伪属性变成真正的属性。如果是requests发起的请求是没有可视化范围,因此一定要解析的是img伪属性值(图片地址)

  Python知识库 最新文章
Python中String模块
【Python】 14-CVS文件操作
python的panda库读写文件
使用Nordic的nrf52840实现蓝牙DFU过程
【Python学习记录】numpy数组用法整理
Python学习笔记
python字符串和列表
python如何从txt文件中解析出有效的数据
Python编程从入门到实践自学/3.1-3.2
python变量
上一篇文章      下一篇文章      查看所有文章
加:2021-09-03 11:50:39  更:2021-09-03 11:51:38 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/15 12:23:14-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码