[django]如何在 search_fields 中包含外键字段

我们知道在 admin.py 中定义 search_fields 可以控制在后台管理界面中能够搜索的字段。

但是,当 search_fields 包含外键字段时,此时进行搜索会报错:

TypeError at /admin/hello/foo/

Related Field has invalid lookup: icontains

解决的办法是修改 search_fields 中的外键字段名称。

将 search_fields 中的外键字段改为 foreign_key__related_fieldname 这种形式就可以了。 这种用法适用于 ForeignKey 及 ManyToManyField 。

models.py

class Hello(models.Model):
    name = models.CharField(max_length=100)

    #...


class Foo(models.Model):
    hello ...
more ...

[django]合并多个查询结果集(queryset)并按字段排序

需求

合并博文的喜爱及转发信息,并按时间排序。

相关 models :

class Post(models.Model):
    #...

    created_at = models.DateTimeField(auto_now_add=True)
    reblog_from = models.ForeignKey('self', null=True, blank=True)

    #...


class Like(models.Model):
    #...

    post = models.ForeignKey(Post)
    created_at = models.DateTimeField(auto_now_add=True)

    #...

解决方案

from itertools import chain
from operator import attrgetter

#...

post = Post.objects.get(pk=post_id ...
more ...

[python]在 zope2 中获取当前时间及格式化输出

可以使用 Zope2 内置的 DateTime() 获取当前时间。

Script(Python)

新建 Script(Python) 文件:

return DateTime()

结果:

2013/03/18 12:38:22.825950 GMT-4

格式输出:

return DateTime().strftime('%Y-%m-%d %H:%M:%S') 结果:

2013/03/18 12:38

DTML

新建 DTML 文件:

<dtml-var expr="DateTime()" fmt="%Y/%m ...
more ...