對python requests的content和text方法的區(qū)別詳解
更新時間:2018年10月11日 10:33:49 作者:Op小劍
今天小編就為大家分享一篇對python requests的content和text方法的區(qū)別詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
問題:
一直在想requests的content和text屬性的區(qū)別,從print 結(jié)果來看是沒有任何區(qū)別的
看下源碼:
@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."""
結(jié)論是:
resp.text返回的是Unicode型的數(shù)據(jù)。
resp.content返回的是bytes型也就是二進制的數(shù)據(jù)。
也就是說,如果你想取文本,可以通過r.text。
如果想取圖片,文件,則可以通過r.content。
(resp.json()返回的是json格式數(shù)據(jù))
舉個栗子
# 例如下載并保存一張圖片
import requests
jpg_url = 'http://img2.niutuku.com/1312/0804/0804-niutuku.com-27840.jpg'
content = requests.get(jpg_url).content
with open('demo.jpg', 'wb') as fp:
fp.write(content)
以上這篇對python requests的content和text方法的區(qū)別詳解就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
python__new__內(nèi)置靜態(tài)方法使用解析
這篇文章主要介紹了python__new__內(nèi)置靜態(tài)方法使用解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-01-01

