DRF: как объединить поле «многие ко многим» в строку в json - PullRequest
0 голосов
/ 06 марта 2020

models.py

class SalesPerson(models.Model):
    name = models.CharField(max_length=50)
    office = models.ForeignKey(Location, on_delete=models.SET_NULL, null=True)

class Project(models.Model):
    title = models.CharField(max_length=50)
    leader = models.ForeignKey(SalesPerson, on_delete=models.SET_NULL, null=True,related_name='leader')    
    location = models.ForeignKey(Location, on_delete=models.SET_NULL, null=True)
    product = models.ManyToManyField(Product)    
    sales_person = models.ManyToManyField(SalesPerson)

serializers.py

class ProjectSerializer(serializers.ModelSerializer):
    leader_name= serializers.ReadOnlyField(source='leader.name')
    location_name= serializers.ReadOnlyField(source='location.name')
    product = serializers.SlugRelatedField(read_only=True, slug_field='name', many=True)    
    sales_person = serializers.SlugRelatedField(read_only=True, slug_field='name', many=True)
    class Meta:
        model = Project
        fields = ('id', 'title', 'leader_name', 'location_name', 'product', 'sales_person')

class SPSerializer(serializers.ModelSerializer):
    projects = ProjectSerializer(many=True, read_only=True, source='project_set')
    office_name= serializers.ReadOnlyField(source='office.city')
    class Meta:
        model = SalesPerson
        fields = ('id', 'name', 'office_name', 'email', 'projects')

результат:

{
        "id": 2,
        "name": "Angela",
        "office_name": "NSW Sydney",
        "email": "angela@angela.com",
        "projects": [
            {
                "id": 1,
                "title": "Mall Orchid",
                "leader_name": "Boris",
                "product": [
                    "Split wall mounted"
                ],
                "sales_person": [
                    "Angela",
                    "Boris",
                    "David"
                ],                
            },
            {
                "id": 6,
                "title": "Mall Petunia",
                "leader_name": "Boris",
                "product": [
                    "Split duct"
                ],
                "sales_person": [
                    "Angela",
                    "Boris",
                    "David"
                ],                
            },            
        ]
    },

Я собираюсь потреблять json с использованием реакционной нативной

Я знаю, как перебирать «проекты»

Однако я хочу избежать перебора «sales_person», чтобы упростить рендеринг массива

Так что я уверен, что у меня есть чтобы превратить sales_person в строку, но сегодня, после поисков в течение многих часов, я не могу найти ответ

Я надеюсь сделать это в Django Rest Framework, а не в Expo React Native, если это возможно

Короче говоря, я хочу получить такой результат:

{
        "id": 2,
        "name": "Angela",
        "office_name": "NSW Sydney",
        "email": "angela@angela.com",
        "projects": [
            {
                "id": 1,
                "title": "Mall Orchid",
                "leader_name": "Boris",
                "product": [
                    "Split wall mounted"
                ],
                "sales_person": "Angela", "Boris", "David",                
            },
            {
                "id": 6,
                "title": "Mall Petunia",
                "leader_name": "Boris",
                "product": [
                    "Split duct"
                ],
                "sales_person": "Angela", "Boris", "David",                
            },            
        ]
    },

Большое спасибо за вашу помощь.

1 Ответ

0 голосов
/ 07 марта 2020

Я нашел ответ

Я пишу его для своей будущей ссылки

class ProjectSerializer(serializers.ModelSerializer):
    leader_name= serializers.ReadOnlyField(source='leader.name')
    location_name= serializers.ReadOnlyField(source='location.city')
    product = serializers.SlugRelatedField(read_only=True, slug_field='name', many=True)
    sales_person = serializers.SerializerMethodField('get_sales_person')
    class Meta:
        model = Project
        fields = ('id', 'title', 'leader_name', 'location_name', 'product', 'sales_person')

    def get_sales_person(self, obj):
        return ', '.join([sales_person.name for sales_person in obj.sales_person.all()])
...