当前位置: 首页 > news >正文

【python】遇上COS美图怎么办?当然是大胆冲呀~

前言

嗨喽~大家好呀,这里是魔王呐 !

在这炎热得夏天~

我不由得想要东西来放松一下~

于是,我采集起了小姐姐COS图~

开发环境:

  • Python 3.8
  • Pycharm

模块使用:

第三方模块 需要安装 在cmd里面 进行 pip install requests / parsel

  • requests
  • parsel

如何安装python第三方模块:

  1. win + R 输入 cmd 点击确定, 输入安装命令 pip install 模块名 (pip install requests) 回车
  2. 在pycharm中点击Terminal(终端) 输入安装命令

实现基本思路:

一. 数据来源分析:

1、分析这些图片url地址在哪?

  • 开发者工具抓包分析, 分析图片链接在什么地方

I. F12 打开开发者工具 --> 刷新网页 <让本网页数据内容重新加载一遍>

II. 通过 Img 可以找图片url地址

-------------------分析图片url地址可以从哪里获得-----------------------

III. 通过图片链接参数 去搜索 数据从哪里来的

获取所有图集 —> 获取所有图集详情页url --> 目录页面发送请求

二. 代码实现步骤

  1. 发送请求, 对于图集目录页发送请求

  2. 获取数据, 获取服务器返回响应数据

  3. 解析数据, 提取我们想要 图集详情页url地址

  4. 发送请求, 对于图集详情页url地址 发送请求

  5. 获取数据, 获取服务器返回响应数据

  6. 解析数据, 提取图片url地址 以及标题

  7. 保存数据, 把图片内容 保存本地文件夹

代码

获取源码链接点击

# 导入数据请求模块  --> 第三方模块 需要 在cmd里面 pip install requests
import requests
# 导入数据解析模块  --> 第三方模块 需要 在cmd里面 pip install parsel
import parsel
# 导入正则模块 --> 内置模块 不需要安装
import re
# 导入文件操作模块 --> 内置模块 不需要安装
import os.path

# 构建翻页
for page in range(2, 450):
    # format 字符串格式化方法
    print(f'正在采集第{page}页的数据内容')
    # 确定请求url地址  <目录页>

伪装 请求头 防止被反爬

    headers = {
        # 浏览器基本身份信息
        'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/101.0.0.0 Safari/537.36'
    }

发送请求

通过requests模块里面get请求方法, 对于url地址发送请求, 并且携带上headers请求头伪装, 最后用自定义变量response接受返回数据

    response = requests.get(url=url, headers=headers)
    # <Response [200]>  表示请求成功了 响应对象
    print(response)

获取数据, 获取服务器返回响应数据 print(response.text)

解析数据, 提取我们想要 图集详情页url地址

推荐使用 parsel

  • 获取 response.text —> 返回html字符串数据内容

  • css选择器 根据标签属性内容, 提取数据

转换数据 转成可以解析对象 <Selector xpath=None data='<html>\r\n<head>\r\n <meta charset="ut...'>

    selector = parsel.Selector(response.text)

使用css选择器提取数据 .pics ul li .tits css语法定位标签/元素 getall 获取所有

    href = selector.css('.pics ul li .tits::attr(href)').getall()

for循环遍历 提取列表元素

    for index in href:

发送请求

对于图集详情页url地址 发送请求 5. 获取数据, 获取服务器返回响应数据

        index_data = requests.get(url=index_url, headers=headers).text

解析数据

提取图片url地址 以及标题

        index_selector = parsel.Selector(index_data)

提取图片链接

.talk_pic img 定位元素/标签 img<标签名>::attr(src) 提取属性 src <属性名>

        img_url_list = index_selector.css('.talk_pic img::attr(src)').getall()

图片标题

        title = index_selector.css('.border_bottom::text').get()

替换特殊字符

        new_title = title = re.sub(r'[\/:*?"<>|]', '', title)

保存数据

        num = 1
        # 自动创建文件夹
        file = f'img\\{new_title}\\'
        # 如果没有这个文件夹
        if not os.path.exists(file):
            # 自动创建文件夹
            os.makedirs(file)
        # for循环遍历 提取列表元素
        for img_url in img_url_list:
            # 获取图片二进制数据
            img_content = requests.get(url=img_url, headers=headers).content
            # 保存图片
            with open(file + new_title + str(num) + '.jpg', mode='wb') as f:
                # 写入数据
                f.write(img_content)
                # 每次循环 +1
                num += 1
            print(title, img_url)

效果








尾语

要成功,先发疯,下定决心往前冲!

学习是需要长期坚持的,一步一个脚印地走向未来!

未来的你一定会感谢今天学习的你。

—— 心灵鸡汤

本文章到这里就结束啦~感兴趣的小伙伴可以复制代码去试试哦 😝

👇问题解答 · 源码获取 · 技术交流 · 抱团学习请联系👇

相关文章:

  • 苏小妍java开发工程师-一面面经
  • 「SpringCloud Alibaba」Sentinel实现熔断与限流
  • 赶紧进来看看---详细介绍五种常用字符串库函数 以及对库函数的模拟实现
  • 浅谈 python在密码学的应用
  • lammps数据后处理:python绘制应力应变曲线 附程序代码
  • 机器学习模型2——决策树
  • Java.lang.Character类中codePointAt(CharSequence seq, int index)方法具有什么功能呢?
  • docker-compose 安装Harbor
  • 微服务项目:尚融宝(52)(核心业务流程:充值服务(3))
  • python的小作业
  • 2022届计算机毕业论文(设计)学生选题参考合集推荐收藏
  • AI艺术的背后:详解文本生成图像模型【基于GAN】
  • NR 物理层编码 - slide4 循环码Cyclic Code
  • 内网渗透-内网信息收集
  • 新学期、新目标、迎接新的自己
  • [分享]iOS开发 - 实现UITableView Plain SectionView和table不停留一起滑动
  • 【Amaple教程】5. 插件
  • 4月23日世界读书日 网络营销论坛推荐《正在爆发的营销革命》
  • Java 内存分配及垃圾回收机制初探
  • leetcode386. Lexicographical Numbers
  • leetcode388. Longest Absolute File Path
  • nginx(二):进阶配置介绍--rewrite用法,压缩,https虚拟主机等
  • PAT A1092
  • Python利用正则抓取网页内容保存到本地
  • Python实现BT种子转化为磁力链接【实战】
  • React as a UI Runtime(五、列表)
  • Storybook 5.0正式发布:有史以来变化最大的版本\n
  • vuex 笔记整理
  • windows下使用nginx调试简介
  • yii2权限控制rbac之rule详细讲解
  • 对话 CTO〡听神策数据 CTO 曹犟描绘数据分析行业的无限可能
  • 浮现式设计
  • 缓存与缓冲
  • 聚簇索引和非聚簇索引
  • 老板让我十分钟上手nx-admin
  • 浅谈web中前端模板引擎的使用
  • 体验javascript之美-第五课 匿名函数自执行和闭包是一回事儿吗?
  • 一个完整Java Web项目背后的密码
  • 硬币翻转问题,区间操作
  • 做一名精致的JavaScripter 01:JavaScript简介
  • ionic入门之数据绑定显示-1
  • shell使用lftp连接ftp和sftp,并可以指定私钥
  • ​LeetCode解法汇总2808. 使循环数组所有元素相等的最少秒数
  • #mysql 8.0 踩坑日记
  • $jQuery 重写Alert样式方法
  • (Ruby)Ubuntu12.04安装Rails环境
  • (附源码)spring boot公选课在线选课系统 毕业设计 142011
  • (附源码)spring boot网络空间安全实验教学示范中心网站 毕业设计 111454
  • (附源码)springboot电竞专题网站 毕业设计 641314
  • (九)c52学习之旅-定时器
  • (免费分享)基于springboot,vue疗养中心管理系统
  • (十八)devops持续集成开发——使用docker安装部署jenkins流水线服务
  • (算法)Game
  • (学习日记)2024.03.25:UCOSIII第二十二节:系统启动流程详解
  • (转)利用ant在Mac 下自动化打包签名Android程序