Django:如何清理表单字段并避免代码重复

我经常需要在使用它之前过滤一些表单数据(保存到数据库等).假设我想在大多数文本字段中以多种形式去除空格并用单个空格替换重复的空格.使用clean_< fieldname>进行此操作并不困难.方法:

# Simplified model with two text fields
class MyModel(models.Model):
    title = models.CharField()
    description = models.CharField()

# Model-based form
class MyForm(forms.ModelForm):
    class Meta:
        model = MyModel

    def clean_title(self):
        title = self.cleaned_data['title']
        return re.sub(r'\s{2,}', ' ', title.strip())

    def clean_description(self):
        description = self.cleaned_data['description']
        return re.sub(r'\s{2,}', ' ', description.strip())

它完全符合我的需要,并且有一个很好的副作用我喜欢:如果用户只输入空格,该字段将被视为空,因此无效(如果需要),我甚至不必抛出ValidationError.

这里显而易见的问题是代码重复.即使我将为此创建一些函数,比如my_text_filter,我将不得不为我的所有表单中的每个文本字段调用它:

from myproject.filters import my_text_filter

class MyForm(forms.ModelForm):
    class Meta:
        model = MyModel

    def clean_title(self):
        return my_text_filter(self.cleaned_data['title'])

    def clean_description(self):
        return my_text_filter(self.cleaned_data['description'])

问题是:在Django中是否有任何标准和简单的方法(我使用版本1.2,如果这很重要)来执行此操作(例如,通过向MyModel添加属性验证器= {‘title’:my_text_filter,’description’:my_text_filter} ),或至少一些或多或少的标准解决方法?我已经阅读了文档中的表单验证和验证器,但是找不到我需要的东西.

最佳答案 因为我知道Django没有任何原生解决方案来解决你的问题.

我只能告诉我如何为自己解决这个问题.

我建议你为你使用
decorator ModelForm.

这里的工作代码(我也使用日志记录模块):

#DECORATOR
def applyValidators(model_form):
    def apply(*args,**kwargs):
        try:
            if hasattr(model_form.Meta.model,"validators"):
                for field_name,fnc in model_form.Meta.model.validators.items():
                    setattr(model_form,"clean_%s" % field_name,fnc)
        except Exception,err:
            logging.error(str(err))
        return model_form(*args,**kwargs)
    return apply

#VALIDATORS
def validator(*args,**kwargs):
    return "SOMEVALUE"

#MODEL
class MyModel(models.Model):
    #Your fields
    .......
    .......
    .......

    #VALIDATE DICT
    validators = {"username":validator,"email":validator}    

#MODEL FORM
@applyValidators
class MyModelForm(forms.ModelForm):
    class Meta:
        model = MyModel
    .......
    .......
    .......
点赞