當前位置: 首頁>>代碼示例>>Python>>正文


Python relations.RelatedField方法代碼示例

本文整理匯總了Python中rest_framework.relations.RelatedField方法的典型用法代碼示例。如果您正苦於以下問題:Python relations.RelatedField方法的具體用法?Python relations.RelatedField怎麽用?Python relations.RelatedField使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在rest_framework.relations的用法示例。


在下文中一共展示了relations.RelatedField方法的6個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: build_json_resource_obj

# 需要導入模塊: from rest_framework import relations [as 別名]
# 或者: from rest_framework.relations import RelatedField [as 別名]
def build_json_resource_obj(cls, fields, resource, resource_instance, resource_name,
                                force_type_resolution=False):
        """
        Builds the resource object (type, id, attributes) and extracts relationships.
        """
        # Determine type from the instance if the underlying model is polymorphic
        if force_type_resolution:
            resource_name = utils.get_resource_type_from_instance(resource_instance)
        resource_data = [
            ('type', resource_name),
            ('id', encoding.force_str(resource_instance.pk) if resource_instance else None),
            ('attributes', cls.extract_attributes(fields, resource)),
        ]
        relationships = cls.extract_relationships(fields, resource, resource_instance)
        if relationships:
            resource_data.append(('relationships', relationships))
        # Add 'self' link if field is present and valid
        if api_settings.URL_FIELD_NAME in resource and \
                isinstance(fields[api_settings.URL_FIELD_NAME], relations.RelatedField):
            resource_data.append(('links', {'self': resource[api_settings.URL_FIELD_NAME]}))
        return OrderedDict(resource_data) 
開發者ID:django-json-api,項目名稱:django-rest-framework-json-api,代碼行數:23,代碼來源:renderers.py

示例2: to_native

# 需要導入模塊: from rest_framework import relations [as 別名]
# 或者: from rest_framework.relations import RelatedField [as 別名]
def to_native(self, obj):
        res = super(ExtendedHyperlinkedModelSerializer, self).to_native(obj)
        if obj:
            res['id'] = obj.serializable_value('pk')
            for field_name, field in self.fields.items():
                if isinstance(field , HyperlinkedRelatedMethod):
                    serializable_value = getattr(obj, field_name)#obj.serializable_value(field_name)()
                    if callable(serializable_value):
                        serializable_value = serializable_value()
                    res[field_name] = {'url': res[field_name]}
                    res[field_name]["id"] = serializable_value.pk if serializable_value else None
                    res[field_name]["descr"] = str(serializable_value) if serializable_value else None
                    res[field_name]["type"] = str(serializable_value.__class__.__name__).lower() if serializable_value else None
                elif isinstance(field , RelatedField) and hasattr(field, 'attname'):
                    serializable_value = obj.serializable_value(field_name)
                    res[field_name] = {'url': res[field_name]}
                    if isinstance(serializable_value, int):
                        res[field_name]["id"] = obj.serializable_value(field_name)
                        res[field_name]["descr"] = str(getattr(obj, field_name))
                    elif serializable_value == None:
                        res[field_name]["id"] = None
                        res[field_name]["descr"] = None
                #else:
                #  print field_name, field.__class__
        return res 
開發者ID:peragro,項目名稱:django-project,代碼行數:27,代碼來源:serializers.py

示例3: get_choices

# 需要導入模塊: from rest_framework import relations [as 別名]
# 或者: from rest_framework.relations import RelatedField [as 別名]
def get_choices(self, cutoff=None):
        """
        Get choices for a field.

        The caller of this method is BrowsableAPIRenderer (indirectly).

        Method is direct copy of ``RelatedField.get_choices``, with one
        modified line (noted below). Line is modified so ``OrderedDict``
        receives hashable keys. The impementation in parent class
        returns result of ``self.to_representaton``, which is not
        hashable in case of this field (``self.to_representaton``
        returns a ``ReturnDict`` object).
        """
        queryset = self.get_queryset()
        if queryset is None:
            # Ensure that field.choices returns something sensible
            # even when accessed with a read-only field.
            return {}

        if cutoff is not None:
            queryset = queryset[:cutoff]

        return OrderedDict(
            [
                (
                    # This line below is modifed.
                    item.pk,
                    self.display_value(item),
                )
                for item in queryset
            ]
        ) 
開發者ID:genialis,項目名稱:resolwe,代碼行數:34,代碼來源:fields.py

示例4: get_links

# 需要導入模塊: from rest_framework import relations [as 別名]
# 或者: from rest_framework.relations import RelatedField [as 別名]
def get_links(self, obj=None, lookup_field='pk'):
        request = self.context.get('request', None)
        view = self.context.get('view', None)
        return_data = OrderedDict()

        kwargs = {lookup_field: getattr(obj, lookup_field) if obj else view.kwargs[lookup_field]}

        self_kwargs = kwargs.copy()
        self_kwargs.update({
            'related_field': self.field_name if self.field_name else self.parent.field_name
        })
        self_link = self.get_url('self', self.self_link_view_name, self_kwargs, request)

        # Assuming RelatedField will be declared in two ways:
        # 1. url(r'^authors/(?P<pk>[^/.]+)/(?P<related_field>\w+)/$',
        #         AuthorViewSet.as_view({'get': 'retrieve_related'}))
        # 2. url(r'^authors/(?P<author_pk>[^/.]+)/bio/$',
        #         AuthorBioViewSet.as_view({'get': 'retrieve'}))
        # So, if related_link_url_kwarg == 'pk' it will add 'related_field' parameter to reverse()
        if self.related_link_url_kwarg == 'pk':
            related_kwargs = self_kwargs
        else:
            related_kwargs = {self.related_link_url_kwarg: kwargs[self.related_link_lookup_field]}

        related_link = self.get_url('related', self.related_link_view_name, related_kwargs, request)

        if self_link:
            return_data.update({'self': self_link})
        if related_link:
            return_data.update({'related': related_link})
        return return_data 
開發者ID:django-json-api,項目名稱:django-rest-framework-json-api,代碼行數:33,代碼來源:relations.py

示例5: extract_attributes

# 需要導入模塊: from rest_framework import relations [as 別名]
# 或者: from rest_framework.relations import RelatedField [as 別名]
def extract_attributes(cls, fields, resource):
        """
        Builds the `attributes` object of the JSON API resource object.
        """
        data = OrderedDict()
        render_nested_as_attribute = json_api_settings.SERIALIZE_NESTED_SERIALIZERS_AS_ATTRIBUTE
        for field_name, field in iter(fields.items()):
            # ID is always provided in the root of JSON API so remove it from attributes
            if field_name == 'id':
                continue
            # don't output a key for write only fields
            if fields[field_name].write_only:
                continue
            # Skip fields with relations
            if isinstance(
                    field, (relations.RelatedField, relations.ManyRelatedField)
            ):
                continue

            if isinstance(field, BaseSerializer) and not render_nested_as_attribute:
                continue

            # Skip read_only attribute fields when `resource` is an empty
            # serializer. Prevents the "Raw Data" form of the browsable API
            # from rendering `"foo": null` for read only fields
            try:
                resource[field_name]
            except KeyError:
                if fields[field_name].read_only:
                    continue

            data.update({
                field_name: resource.get(field_name)
            })

        return utils.format_field_names(data) 
開發者ID:django-json-api,項目名稱:django-rest-framework-json-api,代碼行數:38,代碼來源:renderers.py

示例6: _readable_id_fields

# 需要導入模塊: from rest_framework import relations [as 別名]
# 或者: from rest_framework.relations import RelatedField [as 別名]
def _readable_id_fields(self):
        fields = self._readable_fields
        return {
            field for field in fields
            if (
                isinstance(
                    field,
                    (DynamicRelationField, RelatedField)
                )
                and not isinstance(
                    self.request_fields.get(field.field_name), dict
                )
            )
        } 
開發者ID:AltSchool,項目名稱:dynamic-rest,代碼行數:16,代碼來源:serializers.py


注:本文中的rest_framework.relations.RelatedField方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。