我有一个简单的模型,定义为:
class Article(models.Model):
slug = models.SlugField(max_length=50, unique=True)
title = models.CharField(max_length=100, unique=False)
以及形式:
class ArticleForm(ModelForm):
class Meta:
model = Article
当我尝试更新现有行时,此处验证失败:
if request.method == 'POST':
form = ArticleForm(request.POST)
if form.is_valid(): # POOF
form.save()
创建一个新条目很好,但是,当我尝试更新这些字段中的任何一个时,验证不再通过。
“错误”属性没有任何内容,但是我进入了调试器,并深入到Django胆量中,我看到了:
子弹:“与此无相关的文章已存在”
因此,看起来is_valid()在进行唯一值检查时失败,但是我要做的只是更新该行。
我不能只是做:
form.save(force_update=True)
...因为表单在验证时将失败。
这看起来很简单,但我无法弄清楚。
我正在运行Django 1.0.2
最令人毛骨悚然的是BaseModelForm.validate_unique(),它在表单初始化时被调用。
参考方案
我不认为您实际上是在更新现有文章,而是在创建新文章,大概具有相同的内容,尤其是子句,因此会出现错误。您无法获得更好的错误报告有点奇怪,但是我也不知道您其余视图的外观。
如果您按照这些方式在哪里尝试尝试(我提供了更多可能的视图功能,请对其进行更改以适应您的需要)怎么办?我实际上尚未测试我的代码,所以我确定我至少犯了一个错误,但是您至少应该了解一下总体思路:
def article_update(request, id):
article = get_objects_or_404(Article, pk=id)
if request.method == 'POST':
form = ArticleForm(request.POST, instance=article)
if form.is_valid():
form.save()
return HttpResponseRedirect(to-some-suitable-url)
else:
form = ArticleForm(instance=article)
return render_to_response('article_update.html', { 'form': form })
正如taurean所说,问题是,您应该使用要更新的对象实例化模型表单,否则将获得一个新的对象。
Python GPU资源利用 - python我有一个Python脚本在某些深度学习模型上运行推理。有什么办法可以找出GPU资源的利用率水平?例如,使用着色器,float16乘法器等。我似乎在网上找不到太多有关这些GPU资源的文档。谢谢! 参考方案 您可以尝试在像Renderdoc这样的GPU分析器中运行pyxthon应用程序。它将分析您的跑步情况。您将能够获得有关已使用资源,已用缓冲区,不同渲染状态上…
Python:图像处理可产生皱纹纸效果 - python也许很难描述我的问题。我正在寻找Python中的算法,以在带有某些文本的白色图像上创建皱纹纸效果。我的第一个尝试是在带有文字的图像上添加一些真实的皱纹纸图像(具有透明度)。看起来不错,但副作用是文本没有真正起皱。所以我正在寻找更好的解决方案,有什么想法吗?谢谢 参考方案 除了使用透明性之外,假设您有两张相同尺寸的图像,一张在皱纹纸上明亮,一张在白色背景上有深…
Python uuid4,如何限制唯一字符的长度 - python在Python中,我正在使用uuid4()方法创建唯一的字符集。但是我找不到将其限制为10或8个字符的方法。有什么办法吗?uuid4()ffc69c1b-9d87-4c19-8dac-c09ca857e3fc谢谢。 参考方案 尝试:x = uuid4() str(x)[:8] 输出:"ffc69c1b" Is there a way to…
Django BigInteger自动递增字段作为主键? - python我目前正在建立一个涉及大量集体智慧的项目。每个访问该网站的用户都将创建一个唯一的配置文件,然后将他们的数据用于为自己和其他用户计算最佳匹配。默认情况下,Django创建一个INT(11)id字段来处理模型的主键。我担心这会很快溢出(即,大约2.4b个设备在未事先设置Cookie的情况下访问了该页面)。如何在MySQL中将其更改为BIGINT并在Django自…
Python sqlite3数据库已锁定 - python我在Windows上使用Python 3和sqlite3。我正在开发一个使用数据库存储联系人的小型应用程序。我注意到,如果应用程序被强制关闭(通过错误或通过任务管理器结束),则会收到sqlite3错误(sqlite3.OperationalError:数据库已锁定)。我想这是因为在应用程序关闭之前,我没有正确关闭数据库连接。我已经试过了: connectio…