Python3.7获取网页图片

本文介绍了一种使用Python3.7进行网页爬取的方法,重点介绍了如何抓取慕课网Python专栏的图片资源。通过urllib.request、re和urllib.parse模块,实现了从静态网页抓取图片并下载的功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

参考于 https://blog.csdn.net/sunflowerduidui/article/details/51057995
本人Python新手:本来想简简单单试一个爬虫,结果还是没有找到适合Python3.7这个版本的,之后就参考上面链接,结合自己的一些理解,和上网找的一些资料
同上面链接一样,这里也是仅抓取静态非登录的网页,以慕课网python专栏为例:http://www.imooc.com/course/list?c=python
大体思路如下:
先用urllib.request打开网页,然后用模块re的正则表达式抓取图片的相对位置,然后利于urllib.parse.urljoin这个方法去找到它的绝对地址,然后在进行读取图片。
最后完成的代码如下:

import urllib.request
import re
import urllib.parse
def crawling():
    req = urllib.request.urlopen('http://www.imooc.com/course/list?c=python')  #访问网页
    html=req.read().decode("utf-8") #读取该网页的html代码,同时将其转换为utf-8编码
    #html=req.read().decode("gbk")
    reg=r'src="(.+?\.jpg)"'  #正则表达式,匹配当前图片的字符
    imgre=re.compile(reg)    #创建正则表达式的例子
    imglist=imgre.findall(html)  #在html中找到匹配的项
    count=1
    for img in imglist:
        img_add=urllib.parse.urljoin(html,img)  #通过解析该匹配项的绝对地址,因为提取到的项都是相对位置,需要进行转换
        f=open("D:\\write\\"+str(count)+".jpg",'wb')
        img_html=urllib.request.urlopen("http:"+img_add)
        picture=img_html.read()
        f.write(picture)
        f.close()
        count+=1    
crawling()
大家可以参考一下,仅做简单的爬取。最后提醒,不同的网站有不同的编码,当前的代码可能不适用,需要进行对正则表达式进行修改,同时还要看取到的地址是否为绝对地址,这样才能进行图片的下载。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值