參考網站案例:
https://www.begtut.com/python/ref-requests-post.html
https://blog.csdn.net/junli_chen/article/details/53670887
參考官方:https://requests.readthedocs.io/en/latest/api/?highlight=post#requests.post
一個http請求包括三個部分,為別為請求行,請求報頭,消息主體,類似以下這樣:
請求行
請求報頭
消息主體
HTTP協議規定post提交的數據必須放在消息主體中,但是協議並沒有規定必須使用什麼編碼方式。服務端通過是根據請求頭中的Content-Type字段來獲知請求中的消息主體是用何種方式進行編碼,再對消息主體進行解析。具體的編碼方式包括:
application/x-www-form-urlencoded
最常見post提交數據的方式,以form表單形式提交數據。
application/json
以json串提交數據。
multipart/form-data
一般使用來上傳文件。
Reqeusts支持以form表單形式發送post請求,只需要將請求的參數構造成一個字典,然後傳給requests.post()的data參數即可。
url = 'http://httpbin.org/post'
d = {
'key1': 'value1', 'key2': 'value2'}
r = requests.post(url, data=d)
print r.text
輸出:
{
“args”: {
},
“data”: “”,
“files”: {
},
“form”: {
“key1”: “value1”,
“key2”: “value2”
},
“headers”: {
……
“Content-Type”: “application/x-www-form-urlencoded”,
……
},
“json”: null,
……
}
可以看到,請求頭中的Content-Type字段已設置為application/x-www-form-urlencoded,且d = {‘key1’: ‘value1’, ‘key2’: ‘value2’}以form表單的形式提交到服務端,服務端返回的form字段即是提交的數據。
可以將一json串傳給requests.post()的data參數,
url = 'http://httpbin.org/post'
s = json.dumps({
'key1': 'value1', 'key2': 'value2'})
r = requests.post(url, data=s)
print r.text
輸出:
{
“args”: {
},
“data”: “{
\”key2\”: \”value2\”, \”key1\”: \”value1\”}”,
“files”: {
},
“form”: {
},
“headers”: {
……
“Content-Type”: “application/json”,
……
},
“json”: {
“key1”: “value1”,
“key2”: “value2”
},
……
}
可以看到,請求頭的Content-Type設置為application/json,並將s這個json串提交到服務端中。
Requests也支持以multipart形式發送post請求,只需將一文件傳給requests.post()的files參數即可。
url = 'http://httpbin.org/post'
files = {
'file': open('report.txt', 'rb')}
r = requests.post(url, files=files)
print r.text
輸出:
{
“args”: {
},
“data”: “”,
“files”: {
“file”: “Hello world!”
},
“form”: {
},
“headers”: {
……
“Content-Type”: “multipart/form-data; boundary=467e443f4c3d403c8559e2ebd009bf4a”,
……
},
“json”: null,
……
}
def request_post(data):
r = requests.post("xx", data=data)
print(r.text)
print(type(r.text))
print(eval(r.text))
print(type(eval(r.text)))
return eval(r.text)
調用
data_ = {
'description': '防疫政策', 'id': '3'}
request_post(data_)
返回,默認返回的字符串類型,eval後變成字典類型
<class 'str'>
{
'current_id': '3', 'similar_id_list': [{'166': 0.9442330598831177}, {
'901': 0.9388024806976318}, {
'140': 0.9371911287307739}]}
<class 'dict'>
subscriptable,可下標的
import os
import pandas as pd
import requests
from database.connect_database_mysql import ConnectDatabaseMysql
from config_env.config_envi import common, select_env
connect_database = ConnectDatabaseMysql(select_env)
def request_post(data):
r = requests.post("xx", data=data)
result = eval(r.text)
print(result)
id_list = [key for res in result['similar_id_list'] for key in res.keys()]
sql_read_field = 'id,question,answer'
sql = "select %s from %s where id in (%s, %s, %s, %s, %s)" % (sql_read_field, common['mysql_table'],
id_list[0], id_list[1], id_list[2],
id_list[3], id_list[4])
result_pd = pd.read_sql_query(sql, connect_database.con_target)
index2ans = dict(zip(result_pd['id'], zip(result_pd['question'], result_pd['answer'])))
answer_list = [index2ans[int(id_)] for id_ in id_list]
return answer_list
if __name__ == '__main__':
while True:
human_utterance = input("Please enter your question:").strip()
data_ = {
'description': human_utterance, 'id': '3', 'top_k': '5'}
robot_utterance = request_post(data_)
print("[Bot answer]: %s" % robot_utterance)