django-tastypie 初步实现

重写两个方法def get_object_list(self, request):

request所对应的就是view中的request

写自己的逻辑,返回想要的数据

                        def obj_get_list(self, bundle, **kwargs):

                            return self.get_object_list(bundle.request)

class Price1(Resourse):自己定义模型,写自己所需要的字段

class meta:设置属性。

calss BaseJsonModel(): 创建一个Json数据的数据集


app下的model:

class Goods(models.Model):

    name = models.CharField(max_length=10)

    date = models.DateTimeField()

    price = models.FloatField()


根目录下的url:

v1_api = Api(api_name='v1')

v1_api.register(Price())

v1_api.register(Price1())

urlpatterns = [

    url(r'^admin/', include(admin.site.urls)),

    url(r'^api/', include(v1_api.urls)),

]

app下的自己写一个py文件:


class BaseJsonModel(object):

    '''

    We need a generic object to shove data in/get data from for modelResource.

    '''

    def __init__(self, initial=None):

        self.__dict__['_data'] = {}

        if hasattr(initial, 'items'):

            self.__dict__['_data'] = initial

    def __getattr__(self, name):

        return self._data.get(name, None)

    def __setattr__(self, name, value):

        self.__dict__['_data'][name] = value

    def to_dict(self):

        return self._data


#定义并返回的Json格式的数据集(主要)

class Price1(Resource):

    '''

    用ModelResource实现

    '''

    max_price = fields.CharField(attribute='max_p')  # 最大值

    min_price = fields.CharField(attribute='min_p')  # 最小值

    avg_price = fields.CharField(attribute='avg_p')  # 平均

    # datet = fields.CharField(attribute='datet')

    # gid = fields.CharField(attribute='gid')

    class Meta:

        # objects_class = Goods

        resource_name = 'price1'

        # queryset = Goods.objects.filter(name='good1')

        queryset = Goods.objects.all()

        limit = 10

        authorization = Authorization()

    def get_object_list(self, request):

        good = request.GET['good']

        start_time = request.GET['start']

        end_time = request.GET['end']

        # queryset = Goods.objects.filter(name=good).order_by('-date')

        queryset = Goods.objects.filter(

            name=good, date__range=(start_time, end_time))

        objects = queryset.values('name').annotate(

            max_p=Max('price'),

            min_p=Min('price'),

            avg_p=Avg('price'),

            # datet=('date'),

        )

        print(objects)

        results = []

        for obj in objects:

            print(obj['name'])

            object = BaseJsonModel()  # 创建数据集

            object.name = obj['name']

            object.max_p = obj['max_p']

            object.min_p = obj['min_p']

            object.avg_p = obj['avg_p']

            # object.datet = obj['datet']

            results.append(object)

            # print(result)

            # for i in results:

            #    print(i.name)

        return results

    def obj_get_list(self, bundle, **kwargs):

        return self.get_object_list(bundle.request)

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 原文:https://my.oschina.net/liuyuantao/blog/751438 查询集API 参...
    阳光小镇少爷阅读 3,854评论 0 8
  • Django 1.8.2 文档Home | Table of contents | Index | Modules...
    轩辕小爱阅读 2,384评论 0 2
  • 作者:刘宾, thomas_liub@hotmail.com 请尊重作者著作权,转载请注明出处,谢谢! 数据模型...
    橄榄树下的托马斯阅读 1,938评论 0 0
  • 这是久保田老师在公司9S会议上的讲的话,一个细节决定了一个人的品质!抛开民族情结,学习一下日本人做事的严谨吧! (...
    鉄叔阅读 391评论 7 6
  • 年说过也就过去了,心不由的揪紧了,日子过得真是太快了,快的让人害怕,有些一直拖着不做的事终究还得处理,真是...
    纪娟阅读 231评论 0 0