我构建了一个django-tastypie api。当我点击url时返回数据。 我希望数据根据日期排序。问题是它的字符字段
资源代码:
class myResource(Resource):
date = fields.CharField(attribute='date', default=None)
time = fields.CharField(attribute='time', default=None)
myid = fields.FloatField(attribute='newsid', default=None)
class Meta:
resource_name = 'data'
object_class = dict2obj
def obj_get_list(self, bundle, **kwargs):
bundle = []
#get_data fetches data from mongodb
content = self.get_data()
#content is a dict
for key, value in content.items():
value['myid'] = key
bundle.append(dict2obj(value))
#bundle is a list
return bundle
Url Hit返回:
[{
date: "2013-09-24 08:56:00.000",
myid: 266131,
time: "08:56"
},
{
date: "2013-09-24 09:43:00.000",
myid: 266151,
resource_uri: "/api/eboss/news/266151/"
}]
答案 0 :(得分:0)
我不知道您的dict2obj
,但如果date
和time
确实是日期和时间,则分别使用tastypie.fields.DateField
和tastypie.fields.TimeField
更多合适的。
要进行排序,您可以覆盖apply_sorting(obj_list, options=None)
函数,其中options
是包含查询参数的字典(GET方法)。