使用保存后信号调用函数的递归错误



我有一个类别模型,其中外键是自我的。

class Category(SEO, MetaData):
    parent = models.ForeignKey('self', blank=True, null=True, verbose_name='parent category', on_delete=models.CASCADE)
    path = ArrayField(models.IntegerField(), blank=True, null=True)

我引入了路径字段,以避免小部件中的递归,并对其进行建模,因为不经常这样做。

我使用post_save信号来保存路径:

def _recurse_for_parent(cat_obj, path=None):
    # path at the beginning don't exist and need to be initialized
    if not path:
        path = []
    if cat_obj.parent is not None:
        _recurse_for_parent(cat_obj.parent, path)
    return path

def save_path(sender, instance, **kwargs):
    if instance.parent_id:
        instance.children = _recurse_for_parent(instance.parent)
        instance.save()

post_save.connect(save_path, sender=Category)

我的问题是我得到"最大递归深度错误",但我不明白为什么,因为我使用了条件:

cat_obj.parent is not None:

我在调用instance.save() def save_path中发现了错误,这将触发post_save信号。

因为post_save信号调用save_pathsave path调用save触发post_save,所以我进入了一个无限循环。

我通过将我的逻辑移动到save方法来解决。

函数中有多个问题

def _recurse_for_parent(cat_obj, path=None):
    # path at the beginning don't exist and need to be initialized
    if not path:
        path = []
    if cat_obj.parent is not None:
        _recurse_for_parent(cat_obj.parent, path)
    return path

首先要记住,not []将返回 True,因此如果将 path 设置为 [],该函数每次都会执行相同的操作。请改用is None

其次,从不使用递归调用中的值。

最后想想当两个条件都为 True 时将附加什么。

最新更新