Aquí está la mejor solución si desea algo de flexibilidad adicional y no desea cambiar el campo de su modelo. Simplemente agregue este validador personalizado:
#Imports
from django.core.exceptions import ValidationError
class validate_range_or_null(object):
compare = lambda self, a, b, c: a > c or a < b
clean = lambda self, x: x
message = ('Ensure this value is between %(limit_min)s and %(limit_max)s (it is %(show_value)s).')
code = 'limit_value'
def __init__(self, limit_min, limit_max):
self.limit_min = limit_min
self.limit_max = limit_max
def __call__(self, value):
cleaned = self.clean(value)
params = {'limit_min': self.limit_min, 'limit_max': self.limit_max, 'show_value': cleaned}
if value: # make it optional, remove it to make required, or make required on the model
if self.compare(cleaned, self.limit_min, self.limit_max):
raise ValidationError(self.message, code=self.code, params=params)
Y se puede usar como tal:
class YourModel(models.Model):
....
no_dependents = models.PositiveSmallIntegerField("How many dependants?", blank=True, null=True, default=0, validators=[validate_range_or_null(1,100)])
Los dos parámetros son max y min, y permite valores nulos. Si lo desea, puede personalizar el validador eliminando la instrucción if marcada o cambiar su campo para que esté en blanco = False, null = False en el modelo. Eso, por supuesto, requerirá una migración.
Nota: Tuve que agregar el validador porque Django no valida el rango en PositiveSmallIntegerField, en su lugar, crea una letra pequeña (en postgres) para este campo y obtiene un error de DB si el valor numérico especificado está fuera de rango.
Espero que esto ayude :) Más sobre validadores en Django .
PD. Basé mi respuesta en BaseValidator en django.core.validators, pero todo es diferente excepto el código.