Requests-handling-response-for-http-requests

提供:Dev Guides
移動先:案内検索

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のソースを表示すると、ブラウザにどのように表示されるかと同じように、応答が表示されます-

Typicode

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 の文字が届きます。 バイナリ応答は主に非テキスト要求に使用されます。