Django 查詢數(shù)據(jù)庫(kù)返回JSON的實(shí)現(xiàn)
和前端交互全部使用JSON,如何將數(shù)據(jù)庫(kù)查詢結(jié)果轉(zhuǎn)換成JSON格式
返回多條數(shù)據(jù)
示例
import json from django.http import HttpResponse from django.core import serializers def db_to_json(request): scripts = Scripts.objects.all()[0:1] json_data = serializers.serialize('json', scripts) return HttpResponse(json_data, content_type="application/json")
返回結(jié)果
[{ "fields": { "script_content": "abc", "script_type": "1" }, "model": "home_application.scripts", "pk": "03a0a7cf-567a-11e9-8566-9828a60543bb" }]
功能實(shí)現(xiàn)了,但是我需要返回一個(gè)約定好的JSON格式,查詢結(jié)果放在 data 中
{"message": 'success', "code": '0', "data": []}
代碼如下:
import json from django.http import HttpResponse from django.core import serializers def db_to_json2(request): # 和前端約定的返回格式 result = {"message": 'success', "code": '0', "data": []} scripts = Scripts.objects.all()[0:1] # 序列化為 Python 對(duì)象 result["data"] = serializers.serialize('python', scripts) # 轉(zhuǎn)換為 JSON 字符串并返回 return HttpResponse(json.dumps(result), content_type="application/json")
調(diào)用結(jié)果
{ "message": "success", "code": "0", "data": [{ "fields": { "script_content": "abc", "script_type": "1" }, "model": "home_application.scripts", "pk": "03a0a7cf-567a-11e9-8566-9828a60543bb" }] }
有點(diǎn)難受的是,每條數(shù)據(jù)對(duì)象包含 fields,model,pk三個(gè)對(duì)象,分別代表字段、模型、主鍵,我更想要一個(gè)只包含所有字段的字典對(duì)象。雖然也可以處理,但還是省點(diǎn)性能,交給前端解析吧。
返回單個(gè)對(duì)象
代碼:
from django.forms.models import model_to_dict from django.http import HttpResponse import json def obj_json(request): pk = request.GET.get('script_id') script = Scripts.objects.get(pk=pk) # 轉(zhuǎn)為字典類型 script = model_to_dict(script) return HttpResponse(json.dumps(script), content_type="application/json")
返回JSON:
{ "script_id": "1534d8f0-59ad-11e9-a310-9828a60543bb", "script_content": "3", "script_name": "3", "script_type": "1" }
到此這篇關(guān)于Django 查詢數(shù)據(jù)庫(kù)返回JSON的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)Django 返回JSON內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Django使用原生SQL查詢數(shù)據(jù)庫(kù)詳解
- Django中常用的查詢數(shù)據(jù)方法及查詢對(duì)象的條件詳解
- vue前端和Django后端如何查詢一定時(shí)間段內(nèi)的數(shù)據(jù)
- Django2.1.7 查詢數(shù)據(jù)返回json格式的實(shí)現(xiàn)
- 詳解Django中views數(shù)據(jù)查詢使用locals()函數(shù)進(jìn)行優(yōu)化
- 在django中查詢獲取數(shù)據(jù),get, filter,all(),values()操作
- django之如何按日期查詢數(shù)據(jù)
相關(guān)文章
純用NumPy實(shí)現(xiàn)神經(jīng)網(wǎng)絡(luò)的示例代碼
這篇文章主要介紹了純用NumPy實(shí)現(xiàn)神經(jīng)網(wǎng)絡(luò)的示例代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-10-10Python不同目錄間進(jìn)行模塊調(diào)用的實(shí)現(xiàn)方法
這篇文章主要介紹了Python不同目錄間進(jìn)行模塊調(diào)用的實(shí)現(xiàn)方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-01-01Python使用ntplib庫(kù)同步校準(zhǔn)當(dāng)?shù)貢r(shí)間的方法
NTP網(wǎng)絡(luò)時(shí)間協(xié)議其實(shí)大家平時(shí)或多或少都能接觸到,包括Windows在內(nèi)的操作系統(tǒng)中的很多Internet時(shí)間同步功能都是在NTP的基礎(chǔ)上來(lái)做,這里我們來(lái)看一下Python使用ntplib庫(kù)同步校準(zhǔn)當(dāng)?shù)貢r(shí)間的方法2016-07-07python?time模塊計(jì)算時(shí)間之間的差距(練習(xí)題)
這篇文章主要介紹了python?time模塊計(jì)算時(shí)間之間的差距,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-05-05python深度學(xué)習(xí)tensorflow入門(mén)基礎(chǔ)教程示例
這篇文章主要為大家介紹了python深度學(xué)習(xí)tensorflow入門(mén)基礎(chǔ)教程示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-06-06Python實(shí)現(xiàn)為圖片批量添加隨機(jī)水印
這篇文章主要為大家詳細(xì)介紹了如何使用Python實(shí)現(xiàn)為圖片批量添加隨機(jī)水印,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-11-11Python實(shí)現(xiàn)bilibili時(shí)間長(zhǎng)度查詢的示例代碼
這篇文章主要介紹了Python實(shí)現(xiàn)bilibili時(shí)間長(zhǎng)度查詢的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-01-01Python爬蟲(chóng)工具requests-html使用解析
這篇文章主要介紹了Python爬蟲(chóng)工具requests-html使用解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-04-04