下载器
import os
from urllib import request
from multiprocessing import Process
#使用面向对象简单
class Process2(Process):
def init(self,url):
super().init()
self.url=url
def run(self):#Process类中的run函数自动调用
print(‘当前进程’,os.getpid(),end=’’)
print(‘父进程’,os.getppid())
# 文件名将图片保存
# file_name=url.split(’/’)[-1]
# response=request.urlopen(url)#网络请求#响应一个对象#urlopen网页地址网页地址urlopen
# content=response.read()#获取相应的内容
# with open(file_name,‘wb’) as fq:#保存
# fq.write(content)
class Process2(Process):
def init(self,url):
super().init()
self.url=url
def run(self):#
if name==‘main’:
urlList=[
‘http://www.langlang2017.com/img/banner’ + str(1) + ‘.png’,
‘http://www.langlang2017.com/img/banner’ + str(2) + ‘.png’
]
for url in urlList:
p=Process2(url)
p.start()
进程池
from multiprocessing import Process
from multiprocessing import Pool
import os,time,random
def worker(msg):
start=time.time()
print(’%s开始执行’%msg)
time.sleep(random.random())
end=time.time()
print(’%s执行结束,用时%0.2f秒’%(msg,end-start))
if name == ‘main’:
p=Pool(3)
for i in range(10):
p.apply_async(func=worker,args=(i,))
p.close()#关闭进程池
p.join()#阻塞使其完成