This article is organized based on official documents, and the data interfaces are all provided in official documents
According to the official document, requests is a non-GMO Python HTTP library . Powerful functions and concise syntax. It can be said that requests are inevitable when writing web programs in Python.
Although requests are simple to use, most of their functions do not need to be used frequently. But it is more cumbersome to check the documentation when you need to use it. So I also want to make a sorting and summary. It is convenient for yourself and others.
Attach the official document address
# 安装。注意,千万别安装成request,别少了末尾的spip install resquests复制代码
First import the Requests module
import requests复制代码
r = requests.get('http://httpbin.org/get')# post带参r = requests.post('http://httpbin.org/post', data={'key': 'value'}) r = requests.put('http://httpbin.org/put', data={'key': 'value'}) r = requests.delete('http://httpbin.org/delete') r = requests.head('http://httpbin.org/get') r = requests.options('http://httpbin.org/get')复制代码
requests allows passing URL parameters. By passing parameter key-value pairs to the params
variable, requests will automatically build the corresponding URL.
payload = {'key1': 'value1', 'key2': 'value2'} r = requests.get("http://httpbin.org/get", params=payload)# 注意,字典里值为的None的键并不会被拼接到URL中# 同时,你还可以将列表作为值进行传入payload = {'key1': 'value1', 'key2': ['value2', 'value3']} r = requests.get('http://httpbin.org/get', params=payload) print(r.url)>>> http://httpbin.org/get?key1=value1&key2=value2&key2=value3复制代码
Returns the Unicode data of the response content through text
. requests automatically decodes content from the server.
# 在需要读取文本信息时,可使用text进行获取r = requests.get('http://httpbin.org/get') r.text复制代码
Returns the bytes (binary) data of the response content through content
.
# 在需要获取文件时,可通过content获取# 例如获取一张图片并保存r = requests.get('http://httpbin.org/get/xxx.jpg')with open('example.jpg', 'wb') as img: img.write(r)复制代码
Process the response json data through json()
.
import requests r = requests.get('http://httpbin.org/get') r.json()复制代码
Add headers to the request, just pass dict
to the headers
parameter
# HTTP头部大小写是不敏感的headers = { 'token': token, 'content-type': 'application/json'} url = 'http://httpbin.org/get'r = requests.get(url, headers=headers)复制代码
When the post request has a request body, you can use the json
module to encode the data
url = 'http://httpbin.org/get'body = {'data': data} r = requests.post(url, data=json.dumps(body))复制代码
In addition to using json
In addition to encoding, you can also directly pass the value of the json
parameter
url = 'http://httpbin.org/get'body = {'data': data} r = requests.post(url, json=body)复制代码
Use the open
method to read in binary form After fetching the file, you can easily upload the file
url = 'http://httpbin.org/post'files = {'file': open('report.xls', 'rb')} r = requests.post(url, files=files)# 同时,可以显式地设置文件名、文件类型和请求头url = 'http://httpbin.org/post'files = {'file': ('report.xls', open('report.xls', 'rb'), 'application/vnd.ms-excel', {'Expires': '0'})} r = requests.post(url, files=files)复制代码
You can pass the cookie by passing parameters to the parametercookies
url = 'http://httpbin.org/cookies'cookies = dict(cookies_are='working') r = requests.get(url, cookies=cookies)# 在跨域使用时,可以通过RequestsCookieJar进行域名和路径的定义jar = requests.cookies.RequestsCookieJar() jar.set('tasty_cookie', 'yum', domain='httpbin.org', path='/cookies') jar.set('gross_cookie', 'blech', domain='httpbin.org', path='/elsewhere') url = 'http://httpbin.org/cookies'r = requests.get(url, cookies=jar)复制代码
Get the response status code throughstatus_code
r = requests.get('http://httpbin.org/get') r.status_code>>> 200# requests内置一个状态码查询对象print(r.status_code == requests.codes.ok)>>> True# 如果发生了4xx或者5xx的错误响应,可以使用raise_for_status()函数来抛出异常bad_r = requests.get('http://httpbin.org/status/404') bad_r.status_code>>> 404bad_r.raise_for_status()# 如果请求没有发生错误,则raise_for_status()返回None复制代码
Get the response header throughheaders
r = requests.get('http://httpbin.org/get') r.headers>>> { 'content-encoding': 'gzip', 'transfer-encoding': 'chunked', 'connection': 'close', 'server': 'nginx/1.0.4', 'x-runtime': '148ms', 'etag': '"e1ca502697e5c9317743dc078f67693f"', 'content-type': 'application/json' } # 同时,我们可以通过任意大小写形式来访问这些响应头字段r.headers['Content-Type']>>> 'application/json'r.headers.get('content-type')>>> 'application/json'复制代码
pass cookies
Get cookie data
url = 'http://example.com/some/cookie/setting/url'r = requests.get(url) r.cookies['example_cookie_name']>>> 'example_cookie_value'复制代码
By default, except for HEAD requests, requests will automatically handle all redirects
You can pass history
Method to track redirects
# 例如Github 将所有的HTTP请求重定向到HTTPSr = requests.get('http://github.com') r.url>>> 'https://github.com/'r.status_code>>> 200# 如果使用的时GET、OPTIONS、POST、PUT、PATCH、DELETE请求时,可以通过设置allow_redirects=False来禁用重定向r = requests.get('http://github.com', allow_redirects=False) r.status_code>>> 301# 也可以通过设置allow_redirects=True来启用HEAD请求的重定向r = requests.head('http://github.com', allow_redirects=True)复制代码
This article is a summary of the basic use of requests. Later, we will refer to the official documentation to summarize some advanced usage. Let’s sort out the advanced usage of requests. Proficient use of requests will have the effect of getting twice the result with half the effort when doing web development.
Related free learning recommendations: python video tutorial
The above is the detailed content of Summary and Summary 1: Use of Requests. For more information, please follow other related articles on the PHP Chinese website!