HTTPリクエストの応答の処理

この章では、requestsモジュールから受信した応答の詳細について説明します。以下の詳細について説明します-

  • 応答を得る
  • JSON応答
  • RAWレスポンス
  • バイナリ応答

応答を得る

request.get()メソッドを使用してURLにリクエストを送信します。

import requests
getdata = requests.get('https://jsonplaceholder.typicode.com/users');

getdataには応答オブジェクトがあります。応答のすべての詳細が含まれています。私たちは、(使用して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のソースを表示すると、ブラウザに表示される応答と同じ応答が表示されます。

.html URLを試して、response.textを使用してコンテンツを表示することもできます。これは、ブラウザーでの.htmlURLのソースコンテンツの表示と同じになります。

それでは、同じ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()メソッドを使用して、Httpリクエストの応答をjson形式で取得することもできます。

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を利用でき、さらに追加します。 stream = True 以下に示すようにgetメソッド内-

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応答の開始時。バイナリ応答は、主に非テキスト要求に使用されます。