python爬虫之图片

# -*- coding: utf-8 -*-
# feimengjuan
# 
# re模块主要包含了正则表达式
import re

#urllib.request模块提供了读取Web页面数据的接口
import urllib.request


#抓取网页图片


#根据给定的网址来获取网页详细信息,得到的html就是网页的源代码
def getHtml(url):
    page = urllib.request.urlopen(url) # urllib.request.urlopen()方法用于打开了一个URL地址
    html = page.read().decode() # read().decode() 用于读取URL上的数据并解码
    return html

def getImg(html):
    #利用正则表达式把源代码中的图片地址过滤出来
    reg = r'src="(.+?\.jpg)" pic_ext'   # pic_ext=jpeg 用于正则匹配图片格式
    imgre = re.compile(reg) # re.compile() 可以把正则表达式编译成正则表达式对象,可以重复使用
    imglist = imgre.findall(html) #表示在整个网页中过滤出所有图片的地址,放在imglist中

    x = 0
    for imgurl in imglist:
    	
    	# urllib.request.urlretrieve()方法,直接将远程数据下载到本地,图片通过x一次递增命名
        urllib.request.urlretrieve(imgurl,'E:\haha\%s.jpg' %x) #打开imglist中保存的图片网址,并下载图片保存在本地
        x = x + 1
        print(imgurl)

html = getHtml("http://tieba.baidu.com/p/2460150866")#获取该网址网页详细信息,得到的html就是网页的源代码
getImg(html)#从网页源代码中分析并下载保存图片

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值