• 3.2
  • 5.0
  • 6.1
  • Версия документации: 3.1

Поля и виджеты форм, специфичные для PostgreSQL

Все эти поля и виджеты доступны из модуля django.contrib.postgres.forms.

Поля

SimpleArrayField

class SimpleArrayField(base_field, delimiter=',', max_length=None, min_length=None)

Поле, которое отображается в массив. Он представлен HTML-кодом <input>.

base_field

Это обязательный аргумент.

It specifies the underlying form field for the array. This is not used to render any HTML, but it is used to process the submitted data and validate it. For example:

>>> from django import forms
>>> from django.contrib.postgres.forms import SimpleArrayField

>>> class NumberListForm(forms.Form):
...     numbers = SimpleArrayField(forms.IntegerField())

>>> form = NumberListForm({'numbers': '1,2,3'})
>>> form.is_valid()
True
>>> form.cleaned_data
{'numbers': [1, 2, 3]}

>>> form = NumberListForm({'numbers': '1,2,a'})
>>> form.is_valid()
False
delimiter

This is an optional argument which defaults to a comma: ,. This value is used to split the submitted data. It allows you to chain SimpleArrayField for multidimensional data:

>>> from django import forms
>>> from django.contrib.postgres.forms import SimpleArrayField

>>> class GridForm(forms.Form):
...     places = SimpleArrayField(SimpleArrayField(IntegerField()), delimiter='|')

>>> form = GridForm({'places': '1,2|2,1|4,3'})
>>> form.is_valid()
True
>>> form.cleaned_data
{'places': [[1, 2], [2, 1], [4, 3]]}

Примечание

Поле не поддерживает экранирование разделителя, поэтому будьте осторожны в тех случаях, когда разделитель является допустимым символом в базовом поле. Разделитель не обязательно должен состоять из одного символа.

max_length

Это необязательный аргумент, который подтверждает, что массив не превышает указанную длину.

min_length

Это необязательный аргумент, который подтверждает, что массив достигает как минимум указанной длины.

Удобные формы

SimpleArrayField в большинстве случаев не особенно удобен для пользователя, однако это полезный способ форматирования данных из клиентского виджета для отправки на сервер.

SplitArrayField

class SplitArrayField(base_field, size, remove_trailing_nulls=False)

Это поле обрабатывает массивы, воспроизводя базовое поле фиксированное количество раз.

base_field

Это обязательный аргумент. Он указывает поле формы, которое необходимо повторить.

size

Это фиксированное количество раз, когда базовое поле будет использоваться.

remove_trailing_nulls

По умолчанию установлено значение «False». Если установлено значение False, сохраняется каждое значение из повторяющихся полей. Если установлено значение «True», любые конечные значения, которые являются пустыми, будут удалены из результата. Если базовое поле имеет required=True, но remove_trailing_nulls имеет True, то значения NULL допускаются только в конце и будут удалены.

Несколько примеров:

SplitArrayField(IntegerField(required=True), size=3, remove_trailing_nulls=False)

['1', '2', '3']  # -> [1, 2, 3]
['1', '2', '']  # -> ValidationError - third entry required.
['1', '', '3']  # -> ValidationError - second entry required.
['', '2', '']  # -> ValidationError - first and third entries required.

SplitArrayField(IntegerField(required=False), size=3, remove_trailing_nulls=False)

['1', '2', '3']  # -> [1, 2, 3]
['1', '2', '']  # -> [1, 2, None]
['1', '', '3']  # -> [1, None, 3]
['', '2', '']  # -> [None, 2, None]

SplitArrayField(IntegerField(required=True), size=3, remove_trailing_nulls=True)

['1', '2', '3']  # -> [1, 2, 3]
['1', '2', '']  # -> [1, 2]
['1', '', '3']  # -> ValidationError - second entry required.
['', '2', '']  # -> ValidationError - first entry required.

SplitArrayField(IntegerField(required=False), size=3, remove_trailing_nulls=True)

['1', '2', '3']  # -> [1, 2, 3]
['1', '2', '']  # -> [1, 2]
['1', '', '3']  # -> [1, None, 3]
['', '2', '']  # -> [None, 2]

HStoreField

class HStoreField

Поле, которое принимает данные в кодировке JSON для HStoreField. Он преобразует все значения (кроме нулей) в строки. Он представлен HTML <textarea>.

Удобные формы

HStoreField в большинстве случаев не особенно удобен для пользователя, однако это полезный способ форматирования данных из виджета на стороне клиента для отправки на сервер.

Примечание

В некоторых случаях может быть полезно потребовать или ограничить ключи, действительные для данного поля. Это можно сделать с помощью KeysValidator.

JSONField

class JSONField

A field which accepts JSON encoded data for a JSONField. It is represented by an HTML <textarea>.

Удобные формы

JSONField is not particularly user friendly in most cases, however it is a useful way to format data from a client-side widget for submission to the server.

Не рекомендуется, начиная с версии 3.1: Use django.forms.JSONField instead.

Поля диапазона

Все поля этой группы имеют схожие функциональные возможности для приема данных диапазона. Они основаны на MultiValueField. Они рассматривают одно пропущенное значение как неограниченный диапазон. Они также проверяют, что нижняя граница не превышает верхнюю. Во всех этих полях используется RangeWidget.

IntegerRangeField

class IntegerRangeField

Based on IntegerField and translates its input into NumericRange. Default for IntegerRangeField and BigIntegerRangeField.

Десятичноеполедиапазона

class DecimalRangeField

Based on DecimalField and translates its input into NumericRange. Default for DecimalRangeField.

DateTimeRangeField

class DateTimeRangeField

Based on DateTimeField and translates its input into DateTimeTZRange. Default for DateTimeRangeField.

ДатаРангеФилд

class DateRangeField

Based on DateField and translates its input into DateRange. Default for DateRangeField.

Виджеты

Диапазонвиджет

class RangeWidget(base_widget, attrs=None)

Виджет, используемый всеми полями диапазона. На основе MultiWidget.

RangeWidget имеет один обязательный аргумент:

base_widget

RangeWidget состоит из двух кортежей base_widget.

decompress(value)

Принимает одно «сжатое» значение поля, например DateRangeField, и возвращает кортеж, представляющий нижнюю и верхнюю границу.

Back to Top