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

潍坊网络公司西安关键词优化软件

潍坊网络公司,西安关键词优化软件,上海网站设计 企业,建设购物网站看教程的时候看到一个,生产者跟消费者的概念比较有意思,但是给的代码有问题无法正常运行,于是我就捣鼓了一下。 基本概念就是: 生产者: 一个进程获取网页没页的图片连接(主进程…

看教程的时候看到一个,生产者跟消费者的概念比较有意思,但是给的代码有问题无法正常运行,于是我就捣鼓了一下。
基本概念就是:
                        生产者:     一个进程获取网页没页的图片连接(主进程)
                        消费者:        一个进程下载图片,不同的是每个页面有20张图片,所以在进程中又开了二十线程(子进程)
嗯,概念就是这样接下来看代码

# -*- coding: utf-8 -*-
# @Time :2023/9/30 22:46
# [url=home.php?mod=space&uid=686208]@AuThor[/url]  : 
# @FileName :进程池.线程池配合使用与进程共用变量的使用.py
# [url=home.php?mod=space&uid=2097534]@IED[/url] :PyCharm""""""
import multiprocessing
import requests
import os
from concurrent.futures import ThreadPoolExecutor
from lxml import etreepath = r'D:\img'
headers = {'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) ''AppleWebKit/537.36 (KHTML, like Gecko) ''Chrome/117.0.0.0 Safari/537.36'
}# 获取图片地址
def get_url(url, que):resp = requests.get(url, headers=headers)resp.encoding = resp.apparent_encodingdate = resp.texttree = etree.HTML(date)list_url = tree.xpath('//ul[@class="clearfix"]/li/a')for i in list_url:url_img = i.xpath('./img/@src')que.put('https://pic.netbian.com' + str(*url_img))  # put写入进程变量队列中resp.close()#  下载并保存图片
def download_ove(url, name):try:resp = requests.get(url, headers=headers)path_img = os.path.join(path, f'{name.value}.jpg')with open(path_img, 'wb') as f:f.write(resp.content)print(f'保存成功{name.value}.jpg')name.value += 1  # 数值型进程变量自增except Exception as ex:print('下载出错', ex)#  获取进程队列中的url并启用线程池下载保存图片
def download_img(que, name):# 创建线程池,指定20个线程处理数据with ThreadPoolExecutor(20) as t:while True:try:s = que.get(timeout=3)  # 获取进程队列中的数据,等待3秒若是还没获取到数据抛出异常t.submit(download_ove, s, name)  # 添加进线程池# t.submit(download_ove, s).add_done_callback(err_call_back)  #  获取线程池异常except Exception as ec:print(ec)break#  接收进程池与线程池异常的回调函数
def err_call_back(err):print(f'出错啦~ error:{str(err)}')if __name__ == '__main__':if not os.path.exists(path):os.mkdir(path)que = multiprocessing.Manager().Queue()  # 创建一个进程之间共享的队列变量name = multiprocessing.Manager().Value('i', 0)  # 创建一个进程之间共享的数值型变量,'i'表示整型数字,0表示从0开始for i in range(1, 4):if i != 1:url = f'https://pic.netbian.com/4kdongman/index_{i}.html'else:url = 'https://pic.netbian.com/4kdongman/'get_url(url, que)#  创建进程池,并将函数添加到进程池内,指定最多开辟1个进程处理数据(开多了怕把网址玩崩)with multiprocessing.Pool(1) as pool:pool.apply(download_img, args=(que, name))  # 将函数以同步的方式添加进进程池# apply_async异步方式无法使用不知道为啥,不报异常也不运行download_img函数# pool.apply_async(download_img, args=(que, name), error_callback=err_call_back)pool.close()  # 结束进程池,不在往内添加数据pool.join()  # 等待进程池运行结束print('结束')

本代码仅作为练习所用,大家别把人家网站搞崩了。

http://www.tj-hxxt.cn/news/59012.html

相关文章:

  • 公司网站模版 dedecmsseo推广seo技术培训
  • 网页制作素材小图片谷歌seo和百度区别
  • 公司注册地址备案流程seo排名优化首页
  • 网站推广运营免费网站搭建平台
  • 东北亚科技园里有做网站的吗微信scrm
  • 手机端网站开发流程图长沙百度关键词推广
  • 番禺信息网抖音搜索seo软件
  • 神马关键词快速排名软件关键词优化的策略有哪些
  • 新闻网站怎么做google官网入口
  • 做网站怎么买服务器吗网站关键词怎样优化
  • 成都 企业 网站建设克州seo整站排名
  • 外贸英文网站搭建的公司常德seo快速排名
  • 网站发多少篇文章开始做外链个人博客搭建
  • 网站建设微信公众号小程序app百度知道首页登录
  • 美国做调查网站百度seo有用吗
  • 做短袖的网站小说推广接单平台
  • 郑州高端品牌网站建设上海高端seo公司
  • 站长工具怎么用seo外包杭州
  • 柳州中小企业网站建设sem推广竞价托管
  • 如何复制单页面网站网站流量查询
  • 黄石网站建网站优化公司收费
  • wordpress 链接 拼音百度seo怎么把关键词优化上去
  • 漳州做网站匹配博大钱少a大数据查询
  • 浙江省网站建设公司seo搜索优化招聘
  • wordpress个人主页主题怎么卸载windows优化大师
  • 做境外的赌博网站违法么常德政府网站
  • 北京专业网站制作价格阿里大数据分析平台
  • 找做网站个人宁波seo网络推广多少钱
  • 只做乡村旅游的网站app开发费用标准
  • 网站建设业务爱站网使用体验