django读取数据库(以json格式输出)

1.json格式输出

view.py

request为GET模式时:

def GetMultidata(request):
    if request.method == "GET":
        title = request.GET.get('title') // 获取参数
        needData = Multidata.objects.filter(title=title) // 根据参数获取数据库数据
        json_data = serializers.serialize('json', needData) // 将数据转为json格式
        json_data = json.loads(json_data) // 将数据转为json格式
        data = []
        for i in range(len(json_data)):
            data.append(json_data[i]['fields']) // 提取想要的数据到数组中
        finalData = {
            'data': data // 提将数据转为json格式
        }
        return JsonResponse(finalData, safe=False) // 输出到前端

request为POST模式时:

def GetMultidata(request):
    if request.method == "POST":
        title = request.POST.get('title') // 获取参数
        needData = Multidata.objects.filter(title=title) // 根据参数获取数据库数据
        json_data = serializers.serialize('json', needData) // 将数据转为json格式
        json_data = json.loads(json_data) // 将数据转为json格式
        data = []
        for i in range(len(json_data)):
            data.append(json_data[i]['fields']) // 提取想要的数据到数组中
        finalData = {
            'data': data // 提将数据转为json格式
        }
        return JsonResponse(finalData, safe=False) // 输出到前端

2. 无限极循环

def category_data(request):
    category = CategoryData.objects.all()  // 数据库数据
    category_info = serializers.serialize('json', category) // 将数据转为json格式
    category_info = json.loads(category_info)
    category_info_data = []

    for i in range(len(category_info)):
        category_info_data.append(category_info[i]['fields'])

    lists = []
    tree = {}
    pid = ''
    for i in category_info_data:
        item = i
        tree[item['cat_id']] = item
    root = None
    for i in category_info_data:
        obj = i
        if not obj['pid']:
            root = tree[obj['cat_id']]
            lists.append(root)
        else:
            pid = obj['pid']
            if 'childList' not in tree[pid]:
                tree[pid]['childList'] = []
            tree[pid]['childList'].append(tree[obj['cat_id']])

    data = {
        'data': {
            'category_data': lists
        },
        'code': 200,
        'msg': 'true'
    }
    return JsonResponse(data, safe=False)
  • 0
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. 创建一个Django项目和应用程序 首先,我们需要创建一个Django项目和应用程序。在终端中输入以下命令: ``` django-admin startproject myproject cd myproject python manage.py startapp myapp ``` 2. 安装必要的库 我们需要安装 psycopg2 和 django-jsonfield 库。在终端中输入以下命令: ``` pip install psycopg2 django-jsonfield ``` 3. 配置数据库 在 settings.py 文件中,我们需要配置数据库连接。在 DATABASES 字典中添加以下内容: ``` DATABASES = { 'default': { 'ENGINE': 'django.db.backends.postgresql', 'NAME': 'mydatabase', 'USER': 'mydatabaseuser', 'PASSWORD': 'mypassword', 'HOST': 'localhost', 'PORT': '5432', } } ``` 4. 创建模型 在 models.py 文件中,我们需要创建一个模型来存储 JSON 数据。以下是一个示例模型: ``` from django.db import models from jsonfield import JSONField class MyModel(models.Model): data = JSONField() ``` 5. 迁移数据库 在终端中输入以下命令,创建数据库表: ``` python manage.py makemigrations python manage.py migrate ``` 6. 存储 JSON 数据 在视图函数中,我们可以使用以下代码将 JSON 数据存储到数据库中: ``` from myapp.models import MyModel import json def my_view(request): data = {'name': 'John', 'age': 30} json_data = json.dumps(data) my_model = MyModel(data=json_data) my_model.save() ``` 7. 读取 JSON 数据 在视图函数中,我们可以使用以下代码从数据库读取 JSON 数据: ``` from myapp.models import MyModel import json def my_view(request): my_model = MyModel.objects.first() json_data = my_model.data data = json.loads(json_data) print(data['name']) # 输出 John ``` 这就是将 JSON 数据存储到 PostgreSQL 数据库中的完整过程。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值