1. 使用requests(推荐)

from PIL import Image
import requests
Image.open(requests.get(url, stream=True).raw)

 

2. 使用StringIO

from PIL import Image
from StringIO import StringIO
import requests

r = requests.get("http://a/b/c")
im = Image.open(StringIO(r.content))
im.size

# =======================
from PIL import Image
import urllib2 as urllib
from StringIO import StringIO

fd = urllib.urlopen("http://a/b/c")
im = Image.open(StringIO(fd.read()))
im.size
 

 

3. 使用io.BytesIO

from PIL import Image
import urllib2 as urllib
import io

fd = urllib.urlopen("http://a/b/c")
image_file = io.BytesIO(fd.read())
im = Image.open(image_file)

 ====

#!/usr/bin/env python
# coding=utf-8

from urllib2 import urlopen
import random
import time

from multiprocessing import Pool 

url_root = 'http://www.beianbeian.com/gaoji/validate_code?a='
cnt = 1000

def download_img(url, path='static/uploads/'):
    global cnt
    while cnt < 2000:
        fname = path + "BA%d.jpg" % cnt
        with open(fname, 'wb') as fw:
            try:
                fw.write(urlopen(url).read())
                print fname, 'done'
                cnt += 1
            except Exception as e:
                print 'Error', e
                continue

        time.sleep(0.2)

if __name__ == "__main__":

    pool = Pool(processes=4)
    for i in range(10):
        randNum = random.random()
        url = url_root + str(randNum)
        pool.apply(download_img, args=(url,))
        pool.close()
        pool.join()

 

相关文章:

  • 2022-12-23
  • 2021-06-12
  • 2022-12-23
  • 2021-07-15
  • 2021-12-03
  • 2021-12-31
  • 2022-12-23
猜你喜欢
  • 2022-12-23
  • 2022-12-23
  • 2021-07-13
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
相关资源
相似解决方案