在我的 Django 2.2 应用程序中,我有一个这样的模型:
class Folder(models.Model):
name = models.CharField(max_length=100)
parent_folder = models.ForeignKey("Folder", null=True, on_delete=models.SET_NULL)
基本上,文件夹可以有父文件夹,此文件夹的父文件夹本身可以有父级,依此类推。
所以我想做的是,根据文件夹的name
属性对文件夹进行排序,从顶级文件夹(因此,没有parent_folder
的文件夹(开始,然后在文件夹层次结构中降序。
为了说明这一点,给定表中的以下对象:
+----+---------+---------------+
| id | name | parent_folder |
+----+---------+---------------+
| 1 | fuel | <None> |
| 2 | blabla | 1 |
| 3 | volcano | 2 |
| 4 | awful | 2 |
| 5 | apple | 1 |
| 6 | amazing | <None> |
| 7 | wow | 6 |
+----+---------+---------------+
排序输出 I 除外:
+----+---------+---------------+
| id | name | parent_folder |
+----+---------+---------------+
| 6 | amazing | <None> |
| 7 | wow | 6 |
| 1 | fuel | <None> |
| 5 | apple | 1 |
| 2 | blabla | 1 |
| 4 | awful | 2 |
| 3 | volcano | 2 |
+----+---------+---------------+
我建议为此使用django-mptt
,可以通过pip3 install django-mptt
安装。
将mptt
添加到INSTALLED_APPS
,然后修改模型:
from mptt.models import MPTTModel, TreeForeignKey
class Folder(MPTTModel):
name = models.CharField(max_length=100)
parent = TreeForeignKey('self', on_delete=models.CASCADE, blank=True, null=True)
现在,您只需调用Folder.get_family()
,默认情况下,查询集将按"树顺序"排序。
可以通过使用 Django MPTT 轻松实现。
您需要的内容由.get_family()
返回(请参阅文档(。