python flask解析json數(shù)據(jù)不完整的解決方法
當(dāng)使用Python的flask框架來(lái)開(kāi)發(fā)網(wǎng)站后臺(tái),解析前端Post來(lái)的數(shù)據(jù),通常都會(huì)使用request.form來(lái)獲取前端傳過(guò)來(lái)的數(shù)據(jù),但是如果傳過(guò)來(lái)的數(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ì)我無(wú)效,但是又找不到其他的解決方案?怎么辦?
規(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 -
問(wèn)題解決,可以解析到完整的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格式,寫(xiě)入到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ù),它允許您通過(guò)Python代碼與關(guān)系型數(shù)據(jù)庫(kù)進(jìn)行交互,本文我們將學(xué)習(xí)如何使用Python和SQLAlchemy庫(kù)來(lái)輕松管理數(shù)據(jù)庫(kù),需要的可以參考下2023-05-05在pycharm中使用pipenv創(chuàng)建虛擬環(huán)境和安裝django的詳細(xì)教程
這篇文章主要介紹了在pycharm中使用pipenv來(lái)創(chuàng)建虛擬環(huán)境和安裝django的詳細(xì)教程,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-11-11Python在cmd上打印彩色文字實(shí)現(xiàn)過(guò)程詳解
這篇文章主要介紹了Python在cmd上打印彩色文字實(shí)現(xiàn)過(guò)程詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-08-08Python全面解析json數(shù)據(jù)并保存為csv文件
這篇文章主要介紹了Python全面解析json數(shù)據(jù)并保存為csv文件,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07解決pycharm安裝后代碼區(qū)不能編輯的問(wèn)題
今天小編就為大家分享一篇解決pycharm安裝后代碼區(qū)不能編輯的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-10-10python實(shí)現(xiàn)在字符串中查找子字符串的方法
這篇文章主要介紹了python實(shí)現(xiàn)在字符串中查找子字符串的方法,涉及Python中find方法的相關(guān)使用技巧,需要的朋友可以參考下2015-07-07