python 批量下载图片(python怎么读)

网友投稿 305 2022-08-26


python 批量下载图片(python怎么读)

#coding=utf-8import re,sysimport urllib

def getHtml(url): page = urllib.urlopen(url) html = page.read() return html'''re.compile() 可以把正则表达式编译成一个正则表达式对象.re.findall() 方法读取html 中包含 imgre(正则表达式)的数据。运行脚本将得到整个页面中包含图片的URL地址。'''

def getImg(html): reg = r'src="(.+?\.jpg)" pic_ext' imgre = re.compile(reg) imglist = re.findall(imgre,html) x = 0 n = len(imglist) for imgurl in imglist: urllib.urlretrieve(imgurl,'/Users/newuser/zdx/python/img/%s.jpg' % x) sys.stdout.write(" 已下载:%.2f%%" % float((x+1)*100/n) + '\r') sys.stdout.flush() #不加sys.stdout.flush()只显示结束时的进度 x+=1

def callBack(*arg): print(arg);html = getHtml(""开始下载.."getImg(html)

#这里的核心是用到了urllib.urlretrieve()方法,直接将远程数据下载到本地。

'''urllib.urlretrieve(url, filename, reporthook=None,data=None)参数说明:url:外部或者本地urlfilename:指定了保存到本地的路径(如果未指定该参数,urllib会生成一个临时文件来保存数据);reporthook:是一个回调函数,当连接上服务器、以及相应的数据块传输完毕的时候会触发该回调。我们可以利用这个回调函数来显示当前的下载进度。data:指post到服务器的数据。该方法返回一个包含两个元素的元组(filename, headers),filename表示保存到本地的路径,header表示服务器的响应头。'''


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:python基础学习笔记(三)(python基础教程 豆瓣)
下一篇:JDK源码白话解读之ThreadLocal篇
相关文章

 发表评论

暂时没有评论,来抢沙发吧~