首頁  >  問答  >  主體

python - 如何使用jsom.dumps獲得完整的json資料?

最近都在研究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
天蓬老师天蓬老师2712 天前671

全部回覆(3)我來回復

  • 仅有的幸福

    仅有的幸福2017-05-18 10:58:12

    問題找到了,原因不在於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

    運作正常。

    回覆
    0
  • 给我你的怀抱

    给我你的怀抱2017-05-18 10:58:12

    雷雷

    回覆
    0
  • 给我你的怀抱

    给我你的怀抱2017-05-18 10:58:12

    object 不能直接放到 json 格式里。会报错的。
    django 里,有提供 serialize 把对象序列化的方法。
    至于 flask 就不知道了..

    回覆
    0
  • 取消回覆