我有一个类别模型,其中外键是自我的。
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_path
,save 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 时将附加什么。