如何保存python做的图_python实现简单图片爬虫并保存

先po代码

#coding=utf-8

import urllib.request #3之前的版本直接用urllib即可,下同 #该模块提供了web页面读取数据的接口,使得我们可以像读取本地文件一样读取www或者ftp上的数据

import re

import os

def getHtml(url):

page = urllib.request.urlopen(url);

html = page.read();

return html;

def getImg(html):

imglist = re.findall('img src="(http.*?)"',html)#1 #http.*?表示非贪婪模式的匹配,只要符合http就匹配完成,不再看后面的内容是否匹配,即在能使整个匹配成功的前提下,使用最少的重复

return imglist

html = getHtml("https://www.zhihu.com/question/39731953").decode("utf-8");

imagesUrl = getImg(html);

if os.path.exists("D:/imags") == False:

os.mkdir("D:/imags");

count = 0; #文件的起始名称为 0

for url in imagesUrl:

print(url)

if(url.find('.') != -1):#2

name = url[url.find('.',len(url) - 5):];

bytes = urllib.request.urlopen(url);

f = open("D:/imags/"+str(count)+name, 'wb'); #代开一个文件,准备以二进制写入文件

f.write(bytes.read());#write并不是直接将数据写入文件,而是先写入内存中特定的缓冲区

f.flush();#将缓冲区的数据立即写入缓冲区,并清空缓冲区

f.close();#关闭文件

count+=1;

代码分析:

1.re.findall语法: findall(parttern,string,flags=0)

含义:返回string中与partten匹配的全部字符串,返回形式是数组

2.find()语法:find(str,pos_start,pos_end)

含义:在url中查找str字符串的位置,pos_start是指从哪一个位置开始找,默认值为0,查找的默认位置,默认值为-1,若在url中找不到str,则返回-1

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值