为什么我不能在浏览器中打开时使用python打开这个文件?

时间:2017-08-15 18:43:44

标签: python image file python-requests pillow

我可以在浏览器中打开这个jpg链接,它显示正常。但是当我尝试使用完全相同的标题在python中读取它时,它是不可读的。

PIL说“OSError:无法识别图像文件< _io.BytesIO对象0x00000145034C9EB8>”;并且无法打开写入磁盘的文件。

编辑:我发现如果我删除用户代理标题然后它可以工作.....但奇怪的是,如果我在chrome中输入地址,那么它使用完全相同的用户代理并在浏览器中显示该文件。

import requests
from PIL import Image
import io

headers = {"Host": "i.telegraph.co.uk",
"Connection": "keep-alive",
"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/60.0.3112.90 Safari/537.36",
"Upgrade-Insecure-Requests": "1",
"Accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8",
"Accept-Encoding": "gzip, deflate",
"Accept-Language": "en-US,en;q=0.8"}

link="http://i.telegraph.co.uk/multimedia/archive/02068/police-news_2068686b.jpg"
r=requests.get(link, headers=headers)
print(r.status_code)
print(r.headers)
print(len(r.content))
with open("c:/users/s/documents/temp123.jpg", "wb") as f:
  f.write(r.content)
i=Image.open(io.BytesIO(r.content))

0 个答案:

没有答案