python爬图

闲的无事,看着知乎里种种python优点,按捺不住,装起python3.4。

网上找了点爬行图片的代码,修改至兼容3.4,成功爬行指定url所有jpg图片,代码段如下:

import os
import urllib
import urllib.request
import re
#爬行图片
download_path = os.path.dirname(os.path.abspath(__file__))
class spider(object):
    def __init__(self, url):
        self.url = url
    def parse(self,content):
        pattern = 'src="(http://.*\.jpg)\s*"'
        matchs = re.findall(pattern,content,re.M)
        return matchs    
    def downloads(self,urls):
        d_path = download_path + "/test"
        if not os.path.exists(d_path):
            os.mkdir(d_path)
        for url in urls:
            filename = url.split("/")[-1]
            print (url)
            print ("Downloads %s" % (filename))
            output = "%s/%s" % (d_path, filename)
            urllib.request.urlretrieve(url,output)
           
    def run(self):
        d_url = self.url
        fd = urllib.request.urlopen(d_url)
        try:
            content = fd.read()
            content = content.decode("UTF-8")
            urls = self.parse(content)
            self.downloads(urls)
        finally:
            fd.close()
if __name__ == "__main__":
    sp = spider("http://news.cnfol.com/img/20150814/17638.shtml")
    sp.run()

 

转载于:https://www.cnblogs.com/fxfly/p/4730479.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值