最近都在研究python的flask編程,現在在用jQuery的easyui來寫一個網頁應用,現在問題是,我對資料庫查詢後,想返回標準的json資料給前端,但程序提示:
File "D:\jQueryUI code\Flasktest.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
問題找到了,原因不在於json.dumps裡,而是在於
這一句,透過print total,發現輸出
也就是說想透過這樣得到記錄總數是行不通的。我把程式改了一下,把total透過賦給a:
運作正常。
雷雷
object
不能直接放到json
格式里。会报错的。django
里,有提供serialize
把对象序列化的方法。至于
flask
就不知道了..