python下载图片脚本_[python]非常小的下载图片脚本(非通用)

说在最前面:这不是一个十分通用的下载图片脚本,只是根据我的一个小问题,为了减少我的重复性工作写的脚本。

问题

起因:我的这篇博文什么是真正的程序员浏览量超过了4000+。

问题来了:里面的图片我都是用的七牛的图床,我使用的是免费用户,每个月只有1G的下载流量,今天我收到一封邮件,告诉我我欠费了,欠费了几毛钱。我看了下使用概况,原来是流量超了,一个多G。光我博文发布的那天竟然有近1G的下载流量。。。。

为什么这么做:因为我的文章都是在atom编辑器中,用markdown写的。所以图片都是以‘参考式’的形式插入,url都是七牛生成的。如下图:

发布文章的时候直接全文拷贝到博客园后台,直接就可以发布显示,不需要再上传图片到博客园上。

解决办法:看来为了以后不被莫名其妙的扣费(貌似七牛没有使用量预警,只有月末结算)。我打算把所有的图片上传到博客园。我本地没有这些图片的备份,七牛网页上也没找到批量下载的功能。一共19张图片,我又不想一个个下载。所以就写了个脚本。

脚本

#!/usr/bin/env python

# -*- coding:utf-8 -*-

#

# Author : XueWeiHan

# E-mail : 595666367@qq.com

# Date : 16/3/9 下午4:16

# Desc : 下载图片脚本

import requests

PATH = '/Users/xxx/Downloads/img' #保存图片的路径

# 图片的url(url我已经换成博客园的了,只留了两个)

URLS = [

'[pic1]: http://images2015.cnblogs.com/blog/759200/201603/759200-20160309165053600-1959617063.png "回旋镖"',

'[pic2]: http://images2015.cnblogs.com/blog/759200/201603/759200-20160309165138632-1466995563.png "即兴表演"',

]

class Img(object):

def __init__(self, url):

self.file_name = url.split('/')[-1]

self.url = url

self.path = PATH+'/'+self.file_name

@property

def data(self):

r = requests.get(self.url)

return r.content

def save(self):

with open(self.path, 'wb') as fb:

fb.write(self.data)

for i, url in enumerate(URLS):

url = url.split(' ')[1]

Img(url).save()

print u'第{}/共{}:{}'.format(i+1, len(URLS), 'sucess')

下载完成:

事情没有那么简单

脚本很快就写好了,秒下载完!但是,咱们的__博客园__不支持批量上传。T_T(如果有知道的小伙伴,请告诉无知的我)。

完结

话说,写这篇博客花费的时间是这些操作中最长的~看来我又卖萌了。。。。逃

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值