python - 如何使用jsom.dumps獲得完整的json數(shù)據(jù)?
問題描述
最近都在研究python的flask編程,現(xiàn)在在用jQuery的easyui來寫一個(gè)網(wǎng)頁應(yīng)用,現(xiàn)在問題是,我對(duì)數(shù)據(jù)庫查詢后,想返回標(biāo)準(zhǔn)的json數(shù)據(jù)給前端,但程序提示:
File 'D:jQueryUI code34Flasktest.py', line 23, in p_statusnow p_status_json = json.dumps({’total’:total,’rows’:[{’emp_sn’:i.emp_sn,’name’:i.name,’password’:i.password,’emp_dept_sn’:i.emp_dept_sn,’py_code’:i.py_code,’wb_code’:i.wb_code,’autograph’:i.autograph} for i in user]},indent=4)TypeError: <web.utils.IterBetter instance at 0x00000000033D8948> is not JSON serializable
代碼如下:
@app.route(’/p_statusnow’,methods = [’GET’,’POST’])def p_statusnow(): a=request.values.get(’page’) print a b=request.values.get(’rows’) c=int(b)*(int(a)-1) #user=db.query(’select * from dic_user limit ’) user=db.select (’dic_user’,offset=c,limit=b) total=db.query(’select count(*) from dic_user’) p_status_json = json.dumps({’total’:total,’rows’:[{’emp_sn’:i.emp_sn,’name’:i.name,’password’:i.password,’emp_dept_sn’:i.emp_dept_sn,’py_code’:i.py_code,’wb_code’:i.wb_code,’autograph’:i.autograph} for i in user]},indent=4) #print p_status_json return p_status_json
問題解答
回答1:問題找到了,原因不在于json.dumps里,而是在于
total=db.query(’select count(*) from dic_user’)
這一句,通過print total,發(fā)現(xiàn)輸出
<web.utils.IterBetter instance at 0x00000000037D0888>
也就是說想通過這樣得到記錄總數(shù)是行不通的。我把程序改了一下,把total通過賦給a:
total=db.query(’select count(*) as num from dic_user’) for i in total:a=i.num p_status_json = json.dumps({’total’:a,’rows’:[{’emp_sn’:i.emp_sn,’name’:i.name,’password’:i.password,’emp_dept_sn’:i.emp_dept_sn,’py_code’:i.py_code,’wb_code’:i.wb_code,’autograph’:i.autograph} for i in user]},indent=4) #print p_status_json return p_status_json
運(yùn)行正常。
回答2:from flask import jsonify....def foo(): return jsonify({’test’:1})回答3:
object 不能直接放到 json 格式里。會(huì)報(bào)錯(cuò)的。django 里,有提供 serialize 把對(duì)象序列化的方法。至于 flask 就不知道了..
相關(guān)文章:
1. docker images顯示的鏡像過多,狗眼被亮瞎了,怎么辦?2. 網(wǎng)頁爬蟲 - 用Python3的requests庫模擬登陸B(tài)ilibili總是提示驗(yàn)證碼錯(cuò)誤怎么辦?3. 請(qǐng)教各位大佬,瀏覽器點(diǎn) 提交實(shí)例為什么沒有反應(yīng)4. javascript - Web微信聊天輸入框解決方案5. Matlab和Python編程相似嗎,有兩種都學(xué)過的人可以說說嗎6. javascript - 移動(dòng)端textarea不能上下滑動(dòng),該怎么解決?7. 大家好,請(qǐng)問在python腳本中怎么用virtualenv激活指定的環(huán)境?8. javascript - 微信小程序封裝定位問題(封裝異步并可能多次請(qǐng)求)9. css - 對(duì)于類選擇器使用的問題10. javascript - 關(guān)于audio標(biāo)簽暫停的問題
