python - 如何使用jsom.dumps获得完整的json数据?
问题描述
最近都在研究python的flask编程,现在在用jQuery的easyui来写一个网页应用,现在问题是,我对数据库查询后,想返回标准的json数据给前端,但程序提示:
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,发现输出
<web.utils.IterBetter instance at 0x00000000037D0888>
也就是说想通过这样得到记录总数是行不通的。我把程序改了一下,把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
运行正常。
回答2:from flask import jsonify....def foo(): return jsonify({’test’:1})回答3:
object 不能直接放到 json 格式里。会报错的。django 里,有提供 serialize 把对象序列化的方法。至于 flask 就不知道了..
相关文章:
1. java - git项目迁移到SVN怎么实现的?哪位大神指点指点2. 前端 - 在webstrom上pull代码时出现错误?3. 小白问题getDay()4. css - 手机app中rem的基准值计算错误5. javascript - sublime已经安装了babel插件和sublimelinter-jshint为什么还是显示es6语法错误?6. java - Activity 进入后台再次传值?7. css如何实现图标和文字的“绝对对齐”呢?8. angular.js - ng-include 会缓存html吗?9. 前端 - flex布局采用space-around这种方法,但是最后一行如何让他左对齐?10. chrome - linux系统下如何通过java获取客户端ip和mac地址?

网公网安备