В модели моего блога есть поле для множества тегов:
tags = models.ManyToManyField(PostTag)
Но редактировать его было неудобно, и я изменил свою модель так:
def _get_tagging(self): # Returns comma separated list of tags
tagging = []
for tag in self.tags.all():
tagging.append(tag.name)
return ", ".join(tagging)
def _set_tagging (self, tagging): # Saves tags from comma separated list
tagging = tagging.split(", ")
self.tags.clear()
for tag in tagging:
if len(tag) < 1:
continue
try:
self.tags.add(PostTag.objects.get(name=tag))
except ObjectDoesNotExist:
self.tags.create(name=tag)
tagging = property(_get_tagging, _set_tagging)
Затем я изменил свой admin.py
:
class BlogAdminForm (forms.ModelForm):
tagging = forms.CharField(required=False, label="Tags", max_length=200,
widget=forms.TextInput(attrs={'class':'vTextField'}))
class Meta:
model = BlogPost
def __init__(self, *args, **kwargs):
super(BlogAdminForm, self).__init__(*args, **kwargs)
if kwargs.has_key('instance'):
instance = kwargs['instance']
self.initial['tagging'] = instance.tagging
def save(self, commit=True):
model = super(BlogAdminForm, self).save(commit=False)
model.tagging = self.cleaned_data["tagging"]
if commit:
model.save()
return model
И это работало нормально, но только для редактирования объектов.Я получил ошибку, когда попытался создать новый объект.Зачем?Поскольку отношение «многие ко многим» можно использовать с объектом, которого еще нет в базе данных и который не имеет первичного ключа (экземпляр «BlogPost» должен иметь значение первичного ключа, прежде чем отношение «многие ко многим» можетиспользоваться).Я попытался решить ее, отредактировав метод сохранения следующим образом:
def save(self, commit=True):
model = super(BlogAdminForm, self).save(commit=False)
try:
model.tagging = self.cleaned_data["tagging"]
except ValueError:
model.save()
model.tagging = self.cleaned_data["tagging"]
if commit:
model.save()
Это решило исходную проблему.Но теперь model.save()
не вызывает метод save_model
моей модели администратора:
class BlogAdmin (admin.ModelAdmin):
# ...
form = BlogAdminForm
def save_model(self, request, obj, form, change):
obj.author = request.user
obj.save()
В результате я получаю новую ошибку: null value in column "author_id" violates not-null constraint.
Что я делаю не так?Можно ли вызвать этот метод вручную?