吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 5243|回复: 17
收起左侧

[Python 转载] 整合,python多线程批量下载网页内的图片

 关闭 [复制链接]
ytw6176 发表于 2022-4-23 16:37
本帖最后由 ytw6176 于 2022-4-23 16:43 编辑

小弟前几天刷抖音,看到Python相关视频,比较上头,然后网上找了一些教程,看了5、6个没心情看下去了
决定直接撸demo,在本站翻到两个大哥写的python

demo1:简易封装的python多线程类 - 『编程语言讨论求助区』 - 吾爱破解 - LCG - LSG |安卓破解|病毒分析|www.52pojie.cn
demo2:python爬虫下载网页图片简例 - 『编程语言区』 - 吾爱破解 - LCG - LSG |安卓破解|病毒分析|www.52pojie.cn

看了半天把两个demo大致看懂了。。一边百度一边调试。。感觉这样上手快

看到demo2帖子中2L的建议,就试着整合到一起。  现发给各位python前辈,帮忙看看优化优化

[Python] 纯文本查看 复制代码

import re
import requests
from threading import Thread
from queue import Queue
import time
from bs4 import BeautifulSoup as bsp

q = Queue(100000)

class FastRequests:
    def __init__(
            self,threads=20,headers={
            'User-Agent':'Mozilla/5.0 (X11; Linux aarch64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/88.0.4324.188 Safari/537.36 CrKey/1.54.250320 Edg/99.0.4844.74',
            'Cookie':''
        }
    ):
        self.threads = threads # 线程数 20
        self.headres = headers # 头部
        self.imgUrl = r'https://www.tuba555.net/m/htm9/43816.html'
    
    # 获取网页上所有img元素
    def getImg(self):
        eleGet=requests.get(url=self.imgUrl, headers={"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:86.0) Gecko/20100101 Firefox/86.0"})
        soup=bsp(eleGet.content.decode('gb2312'), 'lxml')
        imgs=soup.find_all('img')
        for i in imgs:
            i=str(i)
            if "tupian_img" in i: # 过滤class为tupian_img的img标签
                kaishi= i.find("src")+5 #  src=" 一共5个字符
                jieshu= i.find("jpg")+3 #  jpg  一共3个字符
                img= i[kaishi:jieshu]
                q.put(img)

    def run(self):
        for i in range(self.threads):
            t = Consumer(self.headres)
            t.start()

class Consumer(Thread):
    def __init__(self,headers):
        Thread.__init__(self)
        self.headers = headers
        self.size = 0
        self.time = 0

    def run(self):
        while True:
            if q.qsize() == 0:
                break
            self.download(q.get())

    def validateTitle(self,title):
        rstr = r"[\/\\\:\*\?\"\<\>\|]"  # '/ \ : * ? " < > |'
        new_title = re.sub(rstr, "_", title)  # 替换为下划线
        return new_title

    def sizeFormat(self,size, is_disk=False, precision=2):

        formats = ['KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB']
        unit = 1000.0 if is_disk else 1024.0
        if not (isinstance(size, float) or isinstance(size, int)):
            raise TypeError('a float number or an integer number is required!')
        if size < 0:
            raise ValueError('number must be non-negative')
        for i in formats:
            size /= unit
            if size < unit:
                return f'{round(size, precision)}{i}'
        return f'{round(size, precision)}{i}'

    def download(self,info):
        title = info.split(r'/')[-1]
        link = info
        if title == '':
            title = self.validateTitle(link.split('/')[-1])
        start_time = time.time()
        response = requests.get(url=link, headers=self.headers, stream=True).content
        end_time = time.time()
        self.time = end_time - start_time
        self.size += response.__sizeof__()

        with open("D:\\" + title,'wb') as f:
            f.write(response)
            f.close()
        print(f'{title} {self.sizeFormat(self.size)} 耗时:{round(self.time,3)}s')

if __name__ == '__main__': # 仅限作为脚本执行,不能被import执行
    fr = FastRequests()
    fr.getImg()
    fr.run()



【测试】多线程下载图片.zip (1.79 KB, 下载次数: 97)

免费评分

参与人数 2吾爱币 +2 热心值 +1 收起 理由
reminiscen + 1 + 1 鼓励转贴优秀软件安全工具和文档!
hecoter + 1 我很赞同!

查看全部评分

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

 楼主| ytw6176 发表于 2022-4-23 20:41
homehome 发表于 2022-4-23 20:36
我相信,不久的将来,楼主又会整合啥的在里面

哈哈  继续学习,整合了再分享
vethenc 发表于 2022-4-23 17:19
feng61328 发表于 2022-4-23 17:45
reminiscen 发表于 2022-4-23 20:18
感谢楼主
homehome 发表于 2022-4-23 20:36
我相信,不久的将来,楼主又会整合啥的在里面
风乘云集水浒卡 发表于 2022-4-23 20:55
牛逼,我都完全看不懂啥意思
zgzxp 发表于 2022-4-23 22:18
mark,以后学习下
649887592 发表于 2022-4-23 22:56
只能下载当前页面,不能下载全部页面的图片?
yqwangjie 发表于 2022-4-24 08:47
感谢分享
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-24 15:57

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表