python requests的content和text方法的区别

 我来答
育知同创教育
2017-11-07 · 百度知道合伙人官方认证企业
育知同创教育
1【专注:Python+人工智能|Java大数据|HTML5培训】 2【免费提供名师直播课堂、公开课及视频教程】 3【地址:北京市昌平区三旗百汇物美大卖场2层,微信公众号:yuzhitc】
向TA提问
展开全部

一直在想requests的content和text属性的区别,从print 结果来看是没有任何区别的

看下源码:

@property
def text(self):
"""Content of the response, in unicode.

If Response.encoding is None, encoding will be guessed using
``chardet``.

The encoding of the response content is determined based solely on HTTP
headers, following RFC 2616 to the letter. If you can take advantage of
non-HTTP knowledge to make a better guess at the encoding, you should
set ``r.encoding`` appropriately before accessing this property.
"""

#content的完整代码就不贴了。
@property
def content(self):
"""Content of the response, in bytes."""123456789101112131415161718

  • 结论是:

  • resp.text返回的是Unicode型的数据。

    resp.content返回的是bytes型也就是二进制的数据。

    也就是说,如果你想取文本,可以通过r.text。

    如果想取图片,文件,则可以通过r.content。

    (resp.json()返回的是json格式数据)

  • 举个栗子

  • # 例如下载并保存一张图片import requests


  • jpg_url = 'http://img2.niutuku.com/1312/0804/0804-niutuku.com-27840.jpg'content = requests.get(jpg_url).contentwith open('demo.jpg', 'wb') as fp:

  •    fp.write(content)

推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式