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

问题

  • 起因:我的这篇博文什么是真正的程序员浏览量超过了4000+。
  • 问题来了:里面的图片我都是用的七牛的图床,我使用的是免费用户,每个月只有1G的下载流量,今天我收到一封邮件,告诉我我欠费了,欠费了几毛钱。我看了下使用概况,原来是流量超了,一个多G。光我博文发布的那天竟然有近1G的下载流量。。。。
  • python使用wget下载图片到指定目录 python如何下载图片_markdown

  • 为什么这么做:因为我的文章都是在atom编辑器中,用markdown写的。所以图片都是以‘参考式’的形式插入,url都是七牛生成的。如下图:
  • python使用wget下载图片到指定目录 python如何下载图片_python_02

  • 发布文章的时候直接全文拷贝到博客园后台,直接就可以发布显示,不需要再上传图片到博客园上。
  • 解决办法:看来为了以后不被莫名其妙的扣费(貌似七牛没有使用量预警,只有月末结算)。我打算把所有的图片上传到博客园。我本地没有这些图片的备份,七牛网页上也没找到批量下载的功能。一共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]:  "回旋镖"',
'[pic2]:  "即兴表演"',
]


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')

#!/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]:  "回旋镖"',
'[pic2]:  "即兴表演"',
]


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')

下载完成:

python使用wget下载图片到指定目录 python如何下载图片_图片上传_03

事情没有那么简单

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

完结

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