django自定义Field实现一个字段存储以逗号分隔的字符串
2014-04-27 00:00
716 查看
实现了在一个字段存储以逗号分隔的字符串,返回一个相应的列表
from django import forms from django.db import models from django.utils.text import capfirst from django.core import exceptions 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)
相关文章推荐
- django自定义Field实现一个字段存储以逗号分隔的字符串
- oracle中PLSQL存储过程中如何使用逗号分隔的集合(逗号分隔字符串转换为一个集合)
- 存储过程拆分Patents表Inventor字段逗号分隔字符串
- SQL巧用逗号分隔的字符串实现类似于 where field in (a,b,c,d)的查询
- SQL 将一个字段内用逗号分隔的内容分成多条记录
- 对一道“写一个算法实现字符串逆序存储,要求不另设串存储空间.”题目的总结!
- MYSQL中利用select查询某字段中包含以逗号分隔的字符串的记录方法
- SQL Server逗号分隔字符串通过户自定义函数返回临时表
- 用一个函数实现将一行字符串中最短的单词输出。此行字符串从主函数传递给该函数。假设字符串中包含的单词以空格作为分隔符号,例如”Asia Games 2010 is held in GuangZhou.”,其中最短的单词是”is”和”in”。
- for xml path 将单表中一个字段用逗号分隔
- 给一个金额字符串插入逗号分隔 保留两位有效数字
- 输入一个字符串,字符串中含有字母、逗号、空格,实现将输入字符中的逗号,空格号去除,字母分行显示
- 用oracle的java存储过程实现BLOB字段的字符串读取
- MYSQL查询某字段中以逗号分隔的字符串的方法
- SQL Server2008中CROSS APPLY的应用范例(三) - 将一个或多个字段内用逗号分隔的内容分成多条记录
- oracle 拆分逗号分隔字符串 实现split
- oracle exists判断一个日期格式的字段是否存在逗号拼接的字符串日期里
- Mysql 存储过程之函数-如判断两个以逗号分隔字符串的包含关系
- sql 查询字段 两个字段以一个字段的形式显示 + 同属一个组的 在一个行列中显示出来 以逗号分隔
- MYSQL中利用select查询某字段中包含以逗号分隔的字符串的记录方法find_in_set