使用Django Rest Framework,只显示相关模型中没有出现的字段?

时间:2015-02-24 14:54:55

标签: django django-rest-framework

我有两个模型(和一个抽象模型):用户,法师和角色。 Mage'继承'来自人物。

角色有updated_date字段,我试图了解用户法师更新的最新日期:

class UserSerializer(serializers.ModelSerializer):
    mage_by_user = serializers.PrimaryKeyRelatedField(
        many=True, queryset=Mage.objects.all())
    mage_last_updated = serializers.ReadOnlyField(
        source='mage_by_user.updated_date')

    class Meta:
        model = User
        fields = ('id', 'username', 'mage_by_user', 'mage_last_updated',)

但由于某种原因,'mage_last_updated'字段才出现!如果我删除了'mage_by_user',那么就会出错,抱怨'mage_last_updated'字段需要它存在。所以在某处它会识别它。

如何解决此问题?我该如何解决?


编辑:

这是json的一些编辑,为了这个问题(即我已经插入了mage对象,以显示updated_date字段)

{
    "id":1,
    "username":"admin",
    "mage_by_user":[{
        "id":3,
        "player":"admin",
        "name":"gandalf",
        "sub_race":"Foo",
        "faction":"Foo",
        "is_published":false,
        "updated_date":"2015-02-11T16:13:16.229890Z",
        "power_level":1,
        "energy_trait":7,
        "virtue":"prudence",
        "vice":"lust",
        "morality":7,
        "size":5,
        "arcana":{
            "Matter":0,
            "Death":0,
            "Fate":1,
            "Mind":0,
            "Prime":0,
            "Forces":0,
            "Spirit":0,
            "Time":0,
            "Space":0,
            "Life":0
        },            
        "mental_attributes":{
            "Wits":0,
            "Intelligence":1,
            "Resolve":0
        },
        "physical_attributes":{
            "Dexterity":0,
            "Stamina":0,
            "Strength":0
        },
        social_attributes":{
            "Composure":0,
            "Presence":0,
            "Manipulation":0
        },
        "mental_skills":{
            "Politics":0,
            "Academics":1,
            "Crafts":0,
            "Medicine":0,
            "Occult":0,
            "Science":0,
            "Investigation":0,
            "Computer":0
        },
        "physical_skills":{
            "Survival":0,
            "Athletics":0,
            "Weaponry":0,
            "Stealth":0,
            "Larceny":0,
            "Brawl":0,
            "Drive":0,
            "Firearms":0
        },
        "social_skills":{
            "Subterfuge":0,
            "Expression":0,
            "Socialize":0,
            "Streetwise":0,
            "Animal Ken":0,
            "Persuasion":0,
            "Empathy":0,
            "Intimidation":0
        }
    }]
}

另外,正如Django抱怨的那样,添加many=True对于只读字段mage_last_updated是不正确的。此处mage_by_user是法师列表中所拥有的'由用户。

1 个答案:

答案 0 :(得分:1)

根据我们在chat中的讨论:

class UserSerializer(serializers.ModelSerializer):
    mage_by_user = serializers.PrimaryKeyRelatedField(
        many=True, queryset=Mage.objects.all())
    mage_last_updated = serializers.SerializerMethodField()

    class Meta:
        model = User
        fields = ('id', 'username', 'mage_by_user', 'mage_last_updated',)

    def get_mage_last_updated(self, obj):
        latest_mage = obj.mage_set.latest('updated_date')
        return latest_mage.updated_date