python爬虫(1) 之下载图片

python爬虫(1) 之下载图片

 

1.爬取对象:http://www.jikexueyuan.com/course/pythonbase/

 

2.爬取目的:将目标网站中该页面所有图片下载下来

 

3.爬取步骤:1)先将需要爬取的网页打开,然后把源代码存下来,存为yuanma.txt文件

       2)编写代码,打开yuanma.txt文件

       3)利用正则表达式匹配,找出含有课程的图片,并把url保存下来

       4)遍历所有图片的url,对每个提交get请求,并将图片内容写入pic文件夹中的文件中,再进行保存

 

4.源代码:

# -*- coding:utf-8 -*-
import re
import requests
#打开文本
file = open('yuanma.txt','r')
html = file.read()
file.close()
#进行匹配
lessons = re.findall('div class="lessonimg-box">(.*?)</div>',html,re.S)
lessons = str(lessons)
pic_url = re.findall('img src="(.*?)" class="lessonimg"',lessons,re.S)
i = 0
for each in pic_url:
    i = i+1
    print("正在下载第"+str(i)+"张图片:"+each)
    pic = requests.get(each)
    fp = open('pic\\'+str(i)+'.jpg','wb')
    fp.write(pic.content)
    fp.close()


 

5.需要注意知识的:

  1)学会正则表达式的使用,(.*?)表示非贪心算法,而(.*)表示贪心算法

  2python脚本的第一行需要用注释表示出编码类型

  3)必须在文件目录下新建pic文件夹

  4)本次代码使用了两次正则表达式,利用先抓大再抓小的方法,就是先爬取到每个课程的代码,在从代码中爬取图片的url

 

6.运行结果:






评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值