Requests-handling-response-for-http-requests
HTTPリクエストの応答の処理
この章では、要求モジュールから受け取った応答の詳細について説明します。 次の詳細について説明します-
- 応答を得る
- JSONレスポンス
- RAW応答
- バイナリ応答
応答を得る
request.get()メソッドを使用してURLへのリクエストを作成します。
import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users');
getdataには応答オブジェクトがあります。 応答の詳細がすべて含まれています。 (text)と(.content)の2つの方法で応答を取得できます。 以下に示すように、response.textを使用すると、データがテキスト形式で返されます-
例
E:\prequests>python makeRequest.py
[
{
"id": 1,
"name": "Leanne Graham",
"username": "Bret",
"email": "[email protected]",
"address": {
"street": "Kulas Light",
"suite": "Apt. 556",
"city": "Gwenborough",
"zipcode": "92998-3874",
"geo": {
"lat": "-37.3159",
"lng": "81.1496"
}
},
"phone": "1-770-736-8031 x56442",
"website": "hildegard.org",
"company": {
"name": "Romaguera-Crona",
"catchPhrase": "Multi-layered client-server neural-net",
"bs": "harness real-time e-markets"
}
},
]
以下に示すようにURLのソースを表示すると、ブラウザにどのように表示されるかと同じように、応答が表示されます-
l URLを試して、response.textを使用してコンテンツを表示することもできます。これは、ブラウザでl URLのソースコンテンツを表示するのと同じです。
ここで、同じURLのresponse.contentを試して、出力を見てみましょう。
例
import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users')
print(getdata.content)
出力
E:\prequests>python makeRequest.py
b'[\n {\n "id": 1,\n "name": "Leanne Graham",\n "username": "Bret",\n
"email": "[email protected]",\n "address": {\n "street": "Kulas Light
",\n "suite": "Apt. 556",\n "city": "Gwenborough",\n "zipcode": "
92998-3874",\n "geo": {\n "lat": "-37.3159",\n "lng": "81.149
6"\n }\n },\n "phone": "1-770-736-8031 x56442",\n "website": "hild
egard.org",\n "company": {\n "name": "Romaguera-Crona",\n "catchPhr
ase": "Multi-layered client-server neural-net",\n "bs": "harness real-time
e-markets"\n }\n },\n {\n "id": 2,\n "name": "Ervin Howell",\n
"username": "Antonette",\n "email": "[email protected]",\n "address": {\n
"street": "Victor Plains",\n "suite": "Suite 879",\n "city": "Wisoky
burgh",\n "zipcode": "90566-7771",\n "geo": {\n "lat": "-43.950
9",\n "lng": "-34.4618"\n }\n },\n "phone": "010-692-6593 x091
25",\n "website": "anastasia.net",\n "company": {\n "name": "Deckow-Crist",
\n "catchPhrase": "Proactive didactic contingency",\n "bs":
"synergize scalable supply-chains"\n }\n },\n {\n "id": 3,\n "name":
"Clementine Bauch",\n "username": "Samantha",\n "email":
"[email protected]",
\n "address": {\n "street": "Douglas Extension",\n "suite": "Suite
847",\n "city": "McKenziehaven",\n "zipcode": "59590-4157",\n "ge
o": {\n "lat": "-68.6102",\n "lng": "-47.0653"\n }\n },\n
応答はバイト単位で示されます。 応答の最初に b の文字が届きます。 リクエストモジュールを使用すると、エンコーディングを使用でき、必要に応じてエンコーディングを変更することもできます。 たとえば、エンコーディングを取得するには、response.encodingを使用できます。
print(getdata.encoding)
出力
utf-8
次のようにエンコーディングを変更できます。-選択したエンコーディングを使用できます。
getdata.encoding = 'ISO-8859-1'
JSONレスポンス
=
次のようにresponse.json()メソッドを使用して、json形式のHttpリクエストの応答を取得することもできます-
例
import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users')
print(getdata.json())
出力
E:\prequests>python makeRequest.py
[{'id': 1, 'name': 'Leanne Graham', 'username': 'Bret', 'email': 'Sincere@april.
biz', 'address': {'street': 'Kulas Light', 'suite': 'Apt. 556', 'city': 'Gwenborough',
'zipcode': '92998-3874', 'geo': {'lat': '-37.3159', 'lng': '81.1496'}},
phone': '1-770-736-8031 x56442', 'website': 'hildegard.org', 'company': {'name':
'Romaguera-Crona', 'catchPhrase': 'Multi-layered client-server neural-net', 'bs':
'harness real-time e-markets'}}]
RAW応答
=
Http URLの生の応答が必要な場合は、response.rawを使用できます。以下に示すように、getメソッド内に stream = True も追加します-
例
import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users', stream=True)
print(getdata.raw)
出力
E:\prequests>python makeRequest.py
<urllib3.response.HTTPResponse object at 0x000000A8833D7B70>
生データからより多くのコンテンツを読み取るには、次のようにすることができます-
print(getdata.raw.read(50))
出力
E:\prequests>python makeRequest.py
b'\x1f\x8b\x08\x00\x00\x00\x00\x00\x00\x03\x95\x98[o\xe38\x12\x85\xdf\xe7W\x10y\
xda\x01F\x82.\xd4m\x9f\xdc\x9dd\xba\xb7\x93\xf4\x06q\xef4\x06\x83A@K\x15\x89m'
バイナリ応答
バイナリ応答を取得するには、response.contentを使用できます。
例
import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users')
print(getdata.content)
出力
E:\prequests>python makeRequest.py
b'[\n {\n "id": 1,\n "name": "Leanne Graham",\n "username": "Bret",\n
"email": "[email protected]",\n "address": {\n "street": "Kulas Light
",\n "suite": "Apt. 556",\n "city": "Gwenborough",\n "zipcode": "
92998-3874",\n "geo": {\n "lat": "-37.3159",\n "lng": "81.149
6"\n }\n },\n "phone": "1-770-736-8031 x56442",\n "website":
"hildegard.org",\n "company": {\n "name": "Romaguera-Crona",\n "catchPhr
ase": "Multi-layered client-server neural-net",\n "bs": "harness real-time
e-markets"\n }\n },\n {\n "id": 2,\n "name": "Ervin Howell",\n "us
ername": "Antonette",\n "email": "[email protected]",\n "address": {\n
"street": "Victor Plains",\n "suite": "Suite 879",\n "city": "Wisoky
burgh",\n "zipcode": "90566-7771",\n "geo": {\n "lat": "-43.950
9",\n "lng": "-34.4618"\n }\n },\n "phone": "010-692-6593 x091
25",\n "website": "anastasia.net",\n "company": {\n "name": "Deckow-Crist",
\n "catchPhrase": "Proactive didactic contingency",\n "bs": "syn
ergize scalable supply-chains"\n }\n },\n {\n "id": 3,\n "name":
"Clementine Bauch",\n "username": "Samantha",\n "email": "[email protected]",
\n "address": {\n "street": "Douglas Extension",\n "suite": "Suite
847",\n "city": "McKenziehaven",\n "zipcode": "59590-4157",\n "
geo": {\n "lat": "-68.6102",\n "lng": "-47.0653"\n }\n },\n
応答はバイト単位で示されます。 応答の最初に b の文字が届きます。 バイナリ応答は主に非テキスト要求に使用されます。