python flask解析json數(shù)據(jù)不完整的解決方法
當(dāng)使用Python的flask框架來開發(fā)網(wǎng)站后臺(tái),解析前端Post來的數(shù)據(jù),通常都會(huì)使用request.form來獲取前端傳過來的數(shù)據(jù),但是如果傳過來的數(shù)據(jù)比較復(fù)雜,其中右array,而且array的元素不是單個(gè)的數(shù)字或者字符串的時(shí)候,就會(huì)出現(xiàn)解析不到數(shù)據(jù)的情況,比如使用下面的js代碼向python flask傳遞數(shù)據(jù)
$.ajax({
"url":"/test",
"method":"post",
"data":{
"test":[
{"test_dict":"1"},
{"test_dict":"2"},
{"test_dict":"3"},
]
}
}
)
當(dāng)我們使用flask的request.form獲取前端的數(shù)據(jù)時(shí),發(fā)現(xiàn)獲取到的數(shù)據(jù)是這樣的:
ImmutableMultiDict([('test', 'test_dict'), ('test', 'test_dict'), ('test', 'test_dict')])
???我的Post數(shù)據(jù)呢?給我post到哪里去了???
這里我就去網(wǎng)上查解決辦法,但是網(wǎng)上哪些刪么使用reqeust.form.getlist()方法好像都對(duì)我無效,但是又找不到其他的解決方案?怎么辦?
規(guī)范一下自己的請(qǐng)求,在前端請(qǐng)求的時(shí)候設(shè)置一個(gè)Json的請(qǐng)求頭,在flask框架鐘直接使用json.loads()方法解析reqeust.get_data(as_text=True),就可以解析到完整的post參數(shù)了!
前端:
$.ajax({
"url":"/test",
"method":"post",
"headers":{"Content-Type": "application/json;charset=utf-8"},//這一句很重要?。?!
"data":{
"test":[
{"test_dict":"1"},
{"test_dict":"2"},
{"test_dict":"3"},
]
}
}
)
python代碼:
@app.route("/test",methods=["GET","POST"])
def test():
print(json.loads(request.get_data(as_text=True)))
return ""
然后看看后臺(tái)打印的信息:
* Serving Flask app "test_flask.py"
* Environment: development
* Debug mode: off
* Running on http://127.0.0.1:5000/ (Press CTRL+C to quit)
{'test': [{'test_dict': '1'}, {'test_dict': '2'}, {'test_dict': '3'}]}
127.0.0.1 - - [25/May/2019 22:43:08] "POST /test HTTP/1.1" 200 -
問題解決,可以解析到完整的json數(shù)據(jù)啦!
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Python解析JSON數(shù)據(jù)的基本方法實(shí)例代碼
- python 調(diào)用API接口 獲取和解析 Json數(shù)據(jù)
- Python讀取JSON數(shù)據(jù)操作實(shí)例解析
- python3實(shí)現(xiàn)從kafka獲取數(shù)據(jù),并解析為json格式,寫入到mysql中
- JSONLINT:python的json數(shù)據(jù)驗(yàn)證庫(kù)實(shí)例解析
- Python使用內(nèi)置json模塊解析json格式數(shù)據(jù)的方法
- 使用Python解析JSON數(shù)據(jù)的基本方法
- 在python?腳本下解析json數(shù)據(jù)
相關(guān)文章
Python+SQLAlchemy輕松實(shí)現(xiàn)管理數(shù)據(jù)庫(kù)
QLAlchemy是一個(gè)強(qiáng)大的ORM(對(duì)象關(guān)系映射)庫(kù),它允許您通過Python代碼與關(guān)系型數(shù)據(jù)庫(kù)進(jìn)行交互,本文我們將學(xué)習(xí)如何使用Python和SQLAlchemy庫(kù)來輕松管理數(shù)據(jù)庫(kù),需要的可以參考下2023-05-05
在pycharm中使用pipenv創(chuàng)建虛擬環(huán)境和安裝django的詳細(xì)教程
這篇文章主要介紹了在pycharm中使用pipenv來創(chuàng)建虛擬環(huán)境和安裝django的詳細(xì)教程,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-11-11
Python在cmd上打印彩色文字實(shí)現(xiàn)過程詳解
這篇文章主要介紹了Python在cmd上打印彩色文字實(shí)現(xiàn)過程詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-08-08
Python全面解析json數(shù)據(jù)并保存為csv文件
這篇文章主要介紹了Python全面解析json數(shù)據(jù)并保存為csv文件,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07
python實(shí)現(xiàn)在字符串中查找子字符串的方法
這篇文章主要介紹了python實(shí)現(xiàn)在字符串中查找子字符串的方法,涉及Python中find方法的相關(guān)使用技巧,需要的朋友可以參考下2015-07-07

