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进行简单的爬虫练习

xpath 解析原理

# 1. 实例化一个 etree 的对象,且需要将被解析的页面源码数据加载到该对象中
# 2. 调用etree对象中的xpath方法,结合xpath的表达式,实现标签的定位和内容的捕获

环境安装

# pip install lxml

如何实例化一个 etree 对象

# 1. 将本地的html文档中的源码数据加载到 etree 对象中
    # etree.parse(filepath)
# 2. 可以从互联网上获取的源码数据,加载到该对象中
    # etree.HTML('page_text')
# xpath('xpath表达式):
    # / : 表示从根节点定位
    # // 表示多个层级
    # // 属性定位: //div[@class='share-body']
    # // 索引定位 //div[@class='share-body']/p[3] 索引是从1开始的
    # 取文本:
        # /text() 获取标签中直系的文本内容 
        # //text() 标签中非直系的文本内容(所有的文本内容)
    # 取属性:
        # /@attrname /img/@src
        # /@attrname /img/@alt
import requests
from lxml import etree
import os

cur_path = os.path.dirname(os.path.abspath(__name__))
img_dir = os.path.join(cur_path, 'images')
os.makedirs(img_dir, exist_ok=True)

def main():
    url = 'https://pic.netbian.com/4kmeinv/'
    headers = {
        'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/99.0.4844.51 Safari/537.36'
    }
    
    t = requests.get(url=url, headers=headers).text
    tree = etree.HTML(t)
    # 解析 src 及 alt 的属性值
    li_list = tree.xpath('//div[@class="slist"]/ul/li')
    for li in li_list:
        img_src = 'https://pic.netbian.com' + li.xpath('.//img/@src')[0]
        img_name = li.xpath('.//img/@alt')[0] + '.jpg'
        # 一般爬虫中处理中文乱码的问题
        img_name = img_name.encode('iso-8859-1').decode('gbk')

        print(img_src)
        print(img_name)
        
        # 请求图片
        img_data = requests.get(url=img_src, headers=headers).content
        img_path = os.path.join(img_dir, img_name)
        with open(img_path, 'wb') as fp:
            fp.write(img_data)
            print(img_name, '下载成功!!!')


if __name__ == '__main__':
    main()
  Python知识库 最新文章
Python中String模块
【Python】 14-CVS文件操作
python的panda库读写文件
使用Nordic的nrf52840实现蓝牙DFU过程
【Python学习记录】numpy数组用法整理
Python学习笔记
python字符串和列表
python如何从txt文件中解析出有效的数据
Python编程从入门到实践自学/3.1-3.2
python变量
上一篇文章      下一篇文章      查看所有文章
加:2022-03-21 20:45:38  更:2022-03-21 20:46:52 
 
开发: 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 19:33:42-

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