recherche

Maison  >  Questions et réponses  >  le corps du texte

python - 如何用requests优雅的下载图片?

requests下载图片太麻烦了,虽然urlretrieve可以一步搞定,但是我想统一使用requests库。
注释部分就是用requests写的。

from urllib.request import urlretrieve

import requests
from bs4 import BeautifulSoup

r = requests.get("http://www.pythonscraping.com")
bs = BeautifulSoup(r.text)
image = bs.find("a", {"id": "logo"}).find("img")["src"]

urlretrieve(image, "logo.jpg")

# ir = requests.get(image, stream=True)
# if ir.status_code == 200:
#     with open('logo.jpg', 'wb') as f:
#         for chunk in ir:
#             f.write(chunk)
PHP中文网PHP中文网2809 Il y a quelques jours377

répondre à tous(1)je répondrai

  • 高洛峰

    高洛峰2017-04-18 09:43:34

    import requests
    from bs4 import BeautifulSoup
    
    r = requests.get("http://www.pythonscraping.com")
    bs = BeautifulSoup(r.text,'lxml')
    image = bs.find("a", {"id": "logo"}).find("img")["src"]
    
    ir = requests.get(image)
    if ir.status_code == 200:
        open('logo.jpg', 'wb').write(ir.content)
     

    ou utilisez une expression régulière

    import re, requests
    
    r = requests.get("http://www.pythonscraping.com")
    p = re.compile(r'<a[^>]*?id="logo"[^<]*?<img[^>]*?src="([^"]*)')
    image = p.findall(r.text)[0]
    ir = requests.get(image)
    sz = open('logo.jpg', 'wb').write(ir.content)
    print('logo.jpg', sz,'bytes')

    répondre
    0
  • Annulerrépondre