- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
嗨,我有一个 Django 项目运行得很好。现在我需要向其添加一个字段来上传文档。但是添加文件内容后,Django 出现错误。即使经过一整天的谷歌搜索也无法解决它。
模型.py
class salesman(models.Model):
user=models.ForeignKey(settings.AUTH_USER_MODEL)
company=models.ForeignKey(Organisation,related_name='salesmancomp')
salesman_name=models.CharField(max_length=250)
salesman_address=models.CharField(max_length=750,null=True,blank=True)
salesman_PAN=models.CharField(max_length=250,null=True,blank=True)
salesman_commission_rate=models.FloatField(null=True,blank=True)
attachment = models.FileField(null=True,blank=True)
class Meta:
unique_together=(('company','salesman_name'),)
def __str__(self):
return self.salesman_name
forms.py
class salesmanform(forms.ModelForm):
def __init__(self,user, *args, **kwargs):
self.request = kwargs.pop('request', None)
super(salesmanform, self).__init__(*args, **kwargs)
class Meta:
model=salesman
fields=('salesman_name','salesman_PAN','salesman_commission_rate','salesman_address','attachment',)
widgets = {
'salesman_address': forms.Textarea
}
def clean(self):
cleaned_data=self.cleaned_data
salesman_name=cleaned_data['salesman_name']
pk=self.instance.pk
insert = pk ==None
if insert:
try:
salesman.objects.get(salesman_name=salesman_name,company=self.request.user.company.entity)
except salesman.DoesNotExist:
pass
else:
raise forms.ValidationError("Salesman already exist.")
else:
pass
return cleaned_data
Views.py
@login_required
def salesmancreate(request):
action="Salesman Creation"
if request.method == 'POST':
rec_form=salesmanform(request.FILES,request=request,user=request.user,data=request.POST)
if rec_form.is_valid():
new_rec = rec_form.save(commit=False)
new_rec.user = request.user
new_rec.company=request.user.company.entity
new_rec.save()
return HttpResponseRedirect(reverse('salesmancreate'),{'section':'added'},messages.add_message(request, messages.SUCCESS,'Salesman added Succesfully'))
else:
rec_form=salesmanform(request=request,user=request.user)
receivablescreated=salesman.objects.filter(company=request.user.company.entity).order_by('-id')
return render(request,'account/salesman.html',{'rec_form':rec_form,'receivablescreated':receivablescreated,'action':action})
我的模板
<form action="." method="post">
<div class="form-group">
{{ rec_form.salesman_name|attr:"class:form-control"|attr:"placeholder:Salesman Name"}}
</div>
<div class="input-group margin-b-20">
{{ rec_form.salesman_commission_rate|attr:"class:form-control"|attr:"placeholder:Commission Perentage" }}
<span class="input-group-addon"><i class="fa fa-envelope-o fa-percent"></i></span>
</div>
<div class="form-group">
{{ rec_form.salesman_PAN|attr:"class:form-control"|attr:"placeholder:PAN of Salesman" }}
</div>
<div class="form-group">
{{ rec_form.salesman_address|attr:"class:form-control"|attr:"style:height: 83px;"|attr:"placeholder:Address of Salesman" }}
</div>
<div class="form-group">
{{ rec_form.attachment|attr:"class:form-control"|attr:"style:height: 83px;"|attr:"placeholder:Address of Salesman" }}
</div>
<div class="form-group clearfix">
<div class="pull-right">
{% csrf_token %}
<button type="submit" class="btn btn-success rounded">Save</button>
</div>
</div>
</form>
错误日志:
TypeError at /salesmancreate/
__init__() got multiple values for keyword argument 'user'
Request Method: POST
Request URL: http://127.0.0.1:8000/salesmancreate/
Django Version: 1.10
Exception Type: TypeError
Exception Value:
__init__() got multiple values for keyword argument 'user'
Exception Location: /Users/pulkitsharma/Documents/workspace/tiktant/invoice/views.py in salesmancreate, line 422
Python Executable: /usr/bin/python
Python Version: 2.7.10
Python Path:
['/Users/pulkitsharma/Documents/workspace/tiktant',
'/Library/Python/2.7/site-packages/pip-8.1.2-py2.7.egg',
'/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python27.zip',
'/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7',
'/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/plat-darwin',
'/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/plat-mac',
'/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/plat-mac/lib-scriptpackages',
'/System/Library/Frameworks/Python.framework/Versions/2.7/Extras/lib/python',
'/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/lib-tk',
'/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/lib-old',
'/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/lib-dynload',
'/System/Library/Frameworks/Python.framework/Versions/2.7/Extras/lib/python/PyObjC',
'/Library/Python/2.7/site-packages']
Server time: Thu, 3 Nov 2016 06:45:34 +0000
Environment:
Request Method: POST
Request URL: http://127.0.0.1:8000/salesmancreate/
Django Version: 1.10
Python Version: 2.7.10
Installed Applications:
('invoice',
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'widget_tweaks')
Installed Middleware:
('django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.auth.middleware.SessionAuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',
'django.middleware.security.SecurityMiddleware')
Traceback:
File "/Library/Python/2.7/site-packages/django/core/handlers/exception.py" in inner
39. response = get_response(request)
File "/Library/Python/2.7/site-packages/django/core/handlers/base.py" in _legacy_get_response
249. response = self._get_response(request)
File "/Library/Python/2.7/site-packages/django/core/handlers/base.py" in _get_response
187. response = self.process_exception_by_middleware(e, request)
File "/Library/Python/2.7/site-packages/django/core/handlers/base.py" in _get_response
185. response = wrapped_callback(request, *callback_args, **callback_kwargs)
File "/Library/Python/2.7/site-packages/django/contrib/auth/decorators.py" in _wrapped_view
23. return view_func(request, *args, **kwargs)
File "/Users/pulkitsharma/Documents/workspace/tiktant/invoice/views.py" in salesmancreate
422. rec_form=salesmanform(request.FILES,request=request,user=request.user,data=request.POST)
Exception Type: TypeError at /salesmancreate/
Exception Value: __init__() got multiple values for keyword argument 'user'
最佳答案
您重写了__init__
方法,以便第一个参数是user
,但您传递了request.FILES
。更改行:
rec_form=salesmanform(request.FILES,request=request,user=request.user,data=request.POST)
至
rec_form = salesmanform(user=request.user, data=request.POST,
files=request.FILES, request=request)
根据经验,尽量不要混合命名参数和位置参数,尤其是当您更改类构造函数签名时。另请考虑将表单名称更改为 SalesmanForm
以更符合 PEP-8类命名约定。
关于python - Django:将文件添加到表单会出现多个参数错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40395455/
简而言之:我想从可变参数模板参数中提取各种选项,但不仅通过标签而且通过那些参数的索引,这些参数是未知的 标签。我喜欢 boost 中的方法(例如 heap 或 lockfree 策略),但想让它与 S
我可以对单元格中的 excel IF 语句提供一些帮助吗? 它在做什么? 对“BaselineAmount”进行了哪些评估? =IF(BaselineAmount, (Variance/Baselin
我正在使用以下方法: public async Task Save(Foo foo,out int param) { ....... MySqlParameter prmparamID
我正在使用 CodeGear RAD Studio IDE。 为了使用命令行参数测试我的应用程序,我多次使用了“运行 -> 参数”菜单中的“参数”字段。 但是每次我给它提供一个新值时,它都无法从“下拉
我已经为信用卡类编写了一些代码,粘贴在下面。我有一个接受上述变量的构造函数,并且正在研究一些方法将这些变量格式化为字符串,以便最终输出将类似于 号码:1234 5678 9012 3456 截止日期:
MySql IN 参数 - 在存储过程中使用时,VarChar IN 参数 val 是否需要单引号? 我已经像平常一样创建了经典 ASP 代码,但我没有更新该列。 我需要引用 VarChar 参数吗?
给出了下面的开始,但似乎不知道如何完成它。本质上,如果我调用 myTest([one, Two, Three], 2); 它应该返回元素 third。必须使用for循环来找到我的解决方案。 funct
将 1113355579999 作为参数传递时,该值在函数内部变为 959050335。 调用(main.c): printf("%d\n", FindCommonDigit(111335557999
这个问题在这里已经有了答案: Is Java "pass-by-reference" or "pass-by-value"? (92 个回答) 关闭9年前。 public class StackOve
我真的很困惑,当像 1 == scanf("%lg", &entry) 交换为 scanf("%lg", &entry) == 1 没有区别。我的实验书上说的是前者,而我觉得后者是可以理解的。 1 =
我正在尝试使用调用 SetupDiGetDeviceRegistryProperty 的函数使用德尔福 7。该调用来自示例函数 SetupEnumAvailableComPorts .它看起来像这样:
我需要在现有项目上实现一些事件的显示。我无法更改数据库结构。 在我的 Controller 中,我(从 ajax 请求)传递了一个时间戳,并且我需要显示之前的 8 个事件。因此,如果时间戳是(转换后)
rails 新手。按照多态关联的教程,我遇到了这个以在create 和destroy 中设置@client。 @client = Client.find(params[:client_id] || p
通过将 VM 参数设置为 -Xmx1024m,我能够通过 Eclipse 运行 Java 程序-Xms256M。现在我想通过 Windows 中的 .bat 文件运行相同的 Java 程序 (jar)
我有一个 Delphi DLL,它在被 Delphi 应用程序调用时工作并导出声明为的方法: Procedure ProduceOutput(request,inputs:widestring; va
浏览完文档和示例后,我还没有弄清楚 schema.yaml 文件中的参数到底用在哪里。 在此处使用 AWS 代码示例:https://github.com/aws-samples/aws-proton
程序参数: procedure get_user_profile ( i_attuid in ras_user.attuid%type, i_data_group in data_g
我有一个字符串作为参数传递给我的存储过程。 dim AgentString as String = " 'test1', 'test2', 'test3' " 我想在 IN 中使用该参数声明。 AND
这个问题已经有答案了: When should I use "this" in a class? (17 个回答) 已关闭 6 年前。 我运行了一些java代码,我看到了一些我不太明白的东西。为什么下
我输入 scroll(0,10,200,10);但是当它运行时,它会传递字符串“xxpos”或“yypos”,我确实在没有撇号的情况下尝试过,但它就是行不通。 scroll = function(xp
我是一名优秀的程序员,十分优秀!