django自定义Field实现一个字段存储以逗号分隔的字符串
class MultiSelectFormField(forms.MultipleChoiceField): widget = forms.CheckboxSelectMultiple
def __init__(self, *args, **kwargs): self.max_choices = kwargs.pop('max_choices', 0) super(MultiSelectFormField, self).__init__(*args, **kwargs)
def clean(self, value): if not value and self.required: raise forms.ValidationError(self.error_messages['required']) # if value and self.max_choices and len(value) > self.max_choices: # raise forms.ValidationError('You must select a maximum of %s choice%s.' # % (apnumber(self.max_choices), pluralize(self.max_choices))) return value
class MultiSelectField(models.Field): __metaclass__ = models.SubfieldBase
def get_internal_type(self): return "CharField"
def get_choices_default(self): return self.get_choices(include_blank=False)
def _get_FIELD_display(self, field): value = getattr(self, field.attname) choicedict = dict(field.choices)
def formfield(self, **kwargs): # don't call super, as that overrides default widget if it has choices defaults = {'required': not self.blank, 'label': capfirst(self.verbose_name), 'help_text': self.help_text, 'choices': self.choices} if self.has_default(): defaults['initial'] = self.get_default() defaults.update(kwargs) return MultiSelectFormField(**defaults)
def get_prep_value(self, value): return value
def get_db_prep_value(self, value, connection=None, prepared=False): if isinstance(value, basestring): return value elif isinstance(value, list): return ",".join(value)
def to_python(self, value): if value is not None: return value if isinstance(value, list) else value.split(',') return ''
def contribute_to_class(self, cls, name): super(MultiSelectField, self).contribute_to_class(cls, name) if self.choices: func = lambda self, fieldname = name, choicedict = dict(self.choices): ",".join([choicedict.get(value, value) for value in getattr(self, fieldname)]) setattr(cls, 'get_%s_display' % self.name, func)
def validate(self, value, model_instance): arr_choices = self.get_choices_selected(self.get_choices_default()) for opt_select in value: if (int(opt_select) not in arr_choices): # the int() here is for comparing with integer choices raise exceptions.ValidationError(self.error_messages['invalid_choice'] % value) return
def get_choices_selected(self, arr_choices=''): if not arr_choices: return False list = [] for choice_selected in arr_choices: list.append(choice_selected[0]) return list
def value_to_string(self, obj): value = self._get_val_from_obj(obj) return self.get_db_prep_value(value)
- Python动态类型的学习---引用的理解
- 垃圾邮件过滤器 python简单实现
- install and upgrade scrapy
- Scrapy的架构介绍
- Centos6 编译安装Python
- 使用Python生成Excel格式的图片
- 让Python文件也可以当bat文件运行
- [Python]推算数独
- Python中zip()函数用法举例
- Python中map()函数浅析
- Python在CAM软件Genesis2000中的应用
- 使用Shiboken为C++和Qt库创建Python绑定
- FREEBASIC 编译可被python调用的dll函数示例
- Python使用RethinkDB总结
- Python,Flex 2和Aptana[js开放工具]
- 国外开发者谈为何放弃PHP而改用Python
- 利用webqq协议使用python登录qq发消息源码参考
- python实现rest请求api示例