python - Django休息框架: get all data in relation

标签 python django django-rest-framework

所以,我有一个 Django 应用程序,我尝试获取 JSON 格式或 QuerySet 格式的所有信息:

models.py

class Flow(models.Model):
    name = models.CharField("nom", primary_key=True, max_length=255)
    BL_applicative = models.CharField("BL applicative", max_length=255,blank=True, null=True)
    comment = models.TextField("commentaire", max_length=1500,blank=True,null=True)
    application = models.ForeignKey('Application', null=True)

class Development(models.Model):
    stability = models.IntegerField("stabilité", default=0)
    unit_test = models.IntegerField("tests unitaires", default=0)
    documentation = models.IntegerField(default=0)
    conception = models.IntegerField(default=0)
    production = models.IntegerField("réalisation", default=0)
    flow = models.ForeignKey('Flow',blank=True,null=True)

class Segment(models.Model):
    index_number = models.IntegerField("indice")
    chain_batch_fueled = models.CharField(max_length=255, blank=True,null=True)
    comment = models.TextField("commentaire", max_length=1500, blank=True,null=True)
    development = models.ForeignKey('Development',verbose_name="Développement", blank=True,null=True)

在独立脚本中,我想获取所有数据,所以我使用了:

seg_ser = serializers.serialize('json', Segment.objects.all())

这就是结果:

[
  {
    "model": "dashboard_tibco.segment",
    "pk": 3,
    "fields": {
      "index_number": 1,
      "chain_batch_fueled": "",
      "comment": "",
      "development": 10
   }
  },
]

可以看到,这里只有数据的信息,没有开发、流程、应用的信息...

有什么解决方案可以获取开发对象的所有字段以及流程对象和应用程序对象的相同字段吗?

解决方案: 感谢杰米的帮助!

所以,这是我的serializers.py:

from rest_framework import serializers

from dashboard_tibco.models import Development, Segment


class DevelopmentSerializer(serializers.ModelSerializer):
    class Meta:
        model = Development
        fields = '__all__'


class SegmentSerializer(serializers.ModelSerializer):
    development = DevelopmentSerializer(read_only=True)

    class Meta:
        many = True
        model = Segment
        fields = '__all__'

我的view.py:

from django.http import HttpResponse
from dashboard_tibco.transformation_document.document import Document
def get_json_doc(request):
    return HttpResponse(Document().get_sql_data_by_application('GRS'))

我的urls.py:

from django.conf.urls import url
from django.contrib import admin


from dashboard_tibco.views import get_json_doc

urlpatterns = [
    url(r'^admin/', admin.site.urls),
    url(r'^json', get_json_doc, name='json'),
]

我的独立脚本与 django Rest 序列化器:

class Document(object):
    def __init__(self):
        /..Make something../

    def get_sql_data_by_application(self):
        serializer = SegmentSerializer(Segment.objects.all(), many=True)
        return JSONRenderer().render(serializer.data)

以及JSONRenderer的结果:

[
  {
    "id": 3,
    "development": {
        "id": 10,
        "status": "En cours",
        "stability": 0,
        "unit_test": 0,
        "documentation": 0,
        "conception": 0,
        "production": 0,
        "modification_date": null,
        "flow": "Batch",
        "achievement_lot": null,
        "project": null
     },
     "name": "",
     "index_number": 1,
     "pivot_subscribed": "",
     "pivot_published": "",
     "chain_batch_fueled": "",
     "comment": "",
     "called": null,
     "caller": null,
     "tuxedo_adapter": null
  },
]

最佳答案

我假设您使用的是 Django Rest Framework。

您需要创建一个自定义序列化器。我没有测试过,但它会是这样的:

class DevelopmentSerializer(serializers.ModelSerializer):
    class Meta:
        model = Development

class SegmentSerializer(serializers.ModelSerializer):
    development = DevelopmentSerializer(read_only=True)
    class Meta:
        many = True
        model = Segment

这告诉 SegementSerializer 在序列化 development 数据时使用 DevelopmentSerializer。默认情况下,它使用 PrimaryKeyRelatedField,这就是为什么您只看到 ID(在本例中为 10)。

关于python - Django休息框架: get all data in relation,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37213416/

相关文章:

Python:带有 Pandas 的时间序列

python - 属性错误 :'NoneType' 对象没有属性 'parent'

javascript - 想在django中使用chartjs绘制数据

python - 创建 Stripe 订阅 Python

python - 如何检查字典是否嵌套 - python

django - _() 或 Django 模板中的 {% trans %}?

python - Django onetoone 与用户的关系不使用查询

python - PostgreSQL 在 'Local time zone' 中保存日期,而我使用 Django 将其设置为 'UTC'

python - 为 Web 应用程序使用的 Python REST API 选择适当的身份验证类

python - 是否可以确保在 Windows 下播放时音频不被修改