python - Django throwing ValueError: too many values to unpack (expected 2) without change to the code
问题描述
我在子文件夹中编写了一个新函数,并且运行良好的 django 项目现在抛出以下错误:
File "C:\Users\me\PycharmProjects\IndicatorAnalyserWebapp\Analyser\Indicators\urls.py", line 4, in <module>
from .views import (
File "C:\Users\me\PycharmProjects\IndicatorAnalyserWebapp\Analyser\Indicators\views.py", line 15, in <module>
from .forms import IndicatorForm, SearchForIndicatorMetaData
File "C:\Users\me\PycharmProjects\IndicatorAnalyserWebapp\Analyser\Indicators\forms.py", line 24, in <module>
class IndicatorForm(forms.ModelForm):
File "C:\Users\me\AppData\Local\Continuum\anaconda37\envs\py34\lib\site-packages\django\forms\models.py", line 252, in __new__
opts.field_classes)
File "C:\Users\me\AppData\Local\Continuum\anaconda37\envs\py34\lib\site-packages\django\forms\models.py", line 166, in fields_for_model
formfield = f.formfield(**kwargs)
File "C:\Users\me\AppData\Local\Continuum\anaconda37\envs\py34\lib\site-packages\django\db\models\fields\__init__.py", line 1873, in formfield
return super(IntegerField, self).formfield(**defaults)
File "C:\Users\me\AppData\Local\Continuum\anaconda37\envs\py34\lib\site-packages\django\db\models\fields\__init__.py", line 872, in formfield
defaults['choices'] = self.get_choices(include_blank=include_blank)
File "C:\Users\me\AppData\Local\Continuum\anaconda37\envs\py34\lib\site-packages\django\db\models\fields\__init__.py", line 802, in get_choices
for choice, __ in choices:
ValueError: too many values to unpack (expected 2)
过去也有人问过类似的问题,而且一直有人使用字典而不是迭代来定义选择。我没有这样做,但我得到了同样的错误。回溯似乎认为问题出在我的forms.py
. 我forms.py
的如下:
from django import forms
from .models import Indicator
def get_indicator_ids():
ids = []
indicator_objects = Indicator.objects.all()
for indicator in indicator_objects:
ids.append(indicator.id)
return ids
class IndicatorDropDown(forms.Form):
def __init__(self, *args, **kwargs):
super(IndicatorDropDown, self).__init__(*args, **kwargs)
self.fields['indicators'] = forms.ChoiceField(choices=get_indicator_ids())
class IndicatorForm(forms.ModelForm):
class Meta:
model = Indicator
fields = '__all__'
exclude = ['creator']
class SearchForIndicatorMetaData(forms.Form):
search_for_indicator_metadata = forms.IntegerField(label='Search for metadata by ID', max_value=999999999)
forms.py
调用模型Indicator
,但这与它工作的最后一次提交相比没有改变。我所有的选择字段都是元组,所以不应该抛出这个错误。任何意见,将不胜感激。
编辑 - 也添加模型
class Indicator(models.Model):
time_periods = (
get_time_periods()
)
months = (
get_months()
)
calculations = (
get_calculations()
)
sex_ids = (
get_all_sexes()
)
age_ids = (
get_all_ages()
)
operands = (
('+', '+'),
('-', '-'),
('*', '*'),
('/', '/')
)
salt_options = get_salt_options_as_tuple()
qof_data_choices = (
('qof-{}-prev-ach-exc-ms-prac.xlsx', 'Musculoskeletal group'),
('qof-{}-prev-ach-exc-neu-prac.xlsx', 'Mental health and neurology group'),
('qof-{}-prev-ach-exc-fer-obs-gyn-prac.xlsx', 'Fertility, obstetrics and gynaecology group'),
('qof-{}-prev-ach-exc-hd-prac.xlsx', 'High dependency and other long term conditions group'),
('qof-{}-prev-ach-exc-ls-prac.xlsx', 'Lifestyle group'),
('qof-{}-prev-ach-exc-resp-prac.xlsx', 'Respiratory group'),
('qof-{}-prev-ach-exc-cv-prac.xlsx', 'Cardiovascular group'),
('qof-{}-prac-dom-ach.xlsx', 'Achievement group'),
('qof-{}-prac-dom-exc.xlsx', 'Exclusion group'),
)
id = models.IntegerField(unique=True, primary_key=True)
source_data_family = models.ForeignKey(IndicatorFamily, on_delete=models.CASCADE, blank=True)
qof_source_data = models.CharField(max_length=100, choices=qof_data_choices, blank=True)
source_sheet = models.CharField(max_length=200, blank=True)
year_range = models.CharField(max_length=2, blank=True)
time_period = models.CharField(max_length=30, choices=time_periods, blank=True)
ageId = models.IntegerField(choices=age_ids, blank=True)
sexId = models.IntegerField(choices=sex_ids)
calculation = models.CharField(max_length=30, choices=calculations, blank=True)
rate = models.IntegerField(blank=True, null=True)
value_declared_independently = models.BooleanField(default=False)
value_column_name = models.CharField(max_length=200, blank=True)
numerator_starts_with_financial_year = models.BooleanField(default=False)
numerator = models.CharField(max_length=200, blank=True)
salt_numerator = models.CharField(max_length=200, blank=True, choices=salt_options)
salt_numerator_operand = models.CharField(max_length=2, choices=operands, blank=True)
salt_numerator_2 = models.CharField(max_length=200, blank=True, choices=salt_options)
numerator_minus_not_caseness = models.BooleanField(default=False)
iapt_q_m_variable_type = models.CharField(max_length=200, blank=True)
iapt_q_m_variable_a = models.CharField(max_length=200, blank=True)
iapt_q_m_variable_b = models.CharField(max_length=200, blank=True)
iapt_q_m_variable_type_denominator = models.CharField(max_length=200, blank=True)
iapt_q_m_variable_a_denominator = models.CharField(max_length=200, blank=True)
iapt_q_m_variable_b_denominator = models.CharField(max_length=200, blank=True)
denominator_starts_with_financial_year = models.BooleanField(default=False)
denominator = models.CharField(max_length=200, blank=True)
denominator_minus_not_caseness = models.BooleanField(default=False)
denominator_source_sheet = models.CharField(max_length=200, blank=True)
salt_denominator = models.CharField(max_length=200, blank=True, choices=salt_options)
salt_denominator_operand = models.CharField(max_length=2, choices=operands, blank=True)
salt_denominator_2 = models.CharField(max_length=200, blank=True, choices=salt_options)
add_denominator_column = models.CharField(max_length=200, blank=True)
additional_denominator_column_starts_with_financial_year = models.BooleanField(default=False)
adjust_denominator_for_person_years = models.BooleanField(default=False)
ccg_over_18_population_as_denominator = models.BooleanField(default=False)
ccg_total_population_as_denominator = models.BooleanField(default=False)
is_count = models.BooleanField(default=False)
is_percentage = models.BooleanField(default=False)
ccg_to_stp = models.BooleanField(default=False)
gp_to_upper_tier_la = models.BooleanField(default=False)
ccg_lookup_required = models.BooleanField(default=False)
drop_depression = models.BooleanField(default=False)
count_non_nulls = models.BooleanField(default=False)
non_null_columns = models.CharField(max_length=300, blank=True)
drop_eng_row = models.BooleanField(default=False)
months_to_quarter = models.BooleanField(default=False)
snapshot = models.BooleanField(default=False)
asterisk_as_two = models.BooleanField(default=False)
creator = models.ForeignKey(settings.AUTH_USER_MODEL, default=1)
denominator_2_equals_denominator = models.BooleanField(default=False)
do_not_suppress_small_numbers = models.BooleanField(default=False)
numerator_is_num_minus_denom = models.BooleanField(default=False)
stp_is_average_not_sum = models.BooleanField(default=False)
mental_health_trust_geographies = models.BooleanField(default=False)
filter_by = models.CharField(max_length=200, blank=True)
# ld_denominator_source_file = models.CharField(max_length=100, choices=qof_data_choices, blank=True)
def __str__(self):
return str(self.id)
编辑 2 - 更新回溯:
File "C:\Users\me\PycharmProjects\IndicatorAnalyserWebapp\Analyser\Indicators\urls.py", line 4, in <module>
from .views import (
File "C:\Users\me\PycharmProjects\IndicatorAnalyserWebapp\Analyser\Indicators\views.py", line 15, in <module>
from .forms import IndicatorForm, SearchForIndicatorMetaData
File "C:\Users\me\PycharmProjects\IndicatorAnalyserWebapp\Analyser\Indicators\forms.py", line 19, in <module>
class IndicatorForm(forms.ModelForm):
File "C:\Users\me\AppData\Local\Continuum\anaconda37\envs\py34\lib\site-packages\django\forms\models.py", line 252, in __new__
opts.field_classes)
File "C:\Users\me\AppData\Local\Continuum\anaconda37\envs\py34\lib\site-packages\django\forms\models.py", line 166, in fields_for_model
formfield = f.formfield(**kwargs)
File "C:\Users\me\AppData\Local\Continuum\anaconda37\envs\py34\lib\site-packages\django\db\models\fields\__init__.py", line 1873, in formfield
return super(IntegerField, self).formfield(**defaults)
File "C:\Users\me\AppData\Local\Continuum\anaconda37\envs\py34\lib\site-packages\django\db\models\fields\__init__.py", line 872, in formfield
defaults['choices'] = self.get_choices(include_blank=include_blank)
File "C:\Users\me\AppData\Local\Continuum\anaconda37\envs\py34\lib\site-packages\django\db\models\fields\__init__.py", line 802, in get_choices
for choice, __ in choices:
ValueError: too many values to unpack (expected 2)
编辑 3 - 添加了从模型调用的函数示例
def get_months():
months = (
('jan', 'January'),
('feb', 'February'),
('mar', 'March'),
('apr', 'April'),
('may', 'May'),
('jun', 'June'),
('jul', 'July'),
('aug', 'August'),
('sep', 'September'),
('oct', 'October'),
('nov', 'November'),
('dec', 'December')
)
return months
def get_time_periods():
time_periods = (
('monthly', 'Monthly'),
('quarterly', 'Quarterly'),
('annual', 'Annual')
)
return time_periods
def get_calculations():
calcs = (
('WILSON', 'Wilson'),
('BYAR', 'Byar')
)
return calcs
解决方案
我所有的选择字段都是元组,所以不应该抛出这个错误。
它会引发错误,因为您在这里向表单添加了一个字段:
... = forms.ChoiceField(choices=get_indicator_ids())
并且get_indicator_ids()
确实不返回2 元组列表。它只是一个扁平的整数列表。
您可以更改 的实现,但实际上,如果我理解正确get_indicator_ids
,您希望在这里可以选择对象。Indicator
然后使用ModelChoiceField
[Django-doc]会很痛苦,例如:
class IndicatorDropDown(forms.Form):
indicators = forms.ModelChoiceField(queryset=Indicator.objects.all())
推荐阅读
- python - 负数中的金钱的 Python 分数问题
- node.js - 按 $in 和布尔值过滤
- linux - 无法从 openssl 创建密钥
- c# - DatePicker 值无法转换。当日期格式为 dd/MM/yyyy
- c# - 制作系统,移除物品不会移除物品
- reactjs - 如何存储输入字段中的当前值并添加新值?
- openapi - OpenAPI 生成器 Maven 插件 Bean 验证 MinProperties 验证
- swift - 如何在同一个“主”视图中切换 2 个不同的视图?SwiftUI
- arrays - 在c中创建一个具有内置长度的数组吗?
- android - 将包名称从两个单词更改为三个单词