BinaryField es un campo especial para almacenar datos binarios sin procesar . Se le puede asignar bytes , bytearray o memoryview . De forma predeterminada, BinaryField establece editable en False , es decir, no se puede incluir en ModelForm. Dado que BinaryField almacena datos sin procesar o, en otros términos, un objeto de python, no se puede ingresar manualmente y debe asignarse a través de una vista o shell de django. Esto es lo que significa editable a False , es decir, no se puede editar a través de ningún formulario.
Sintaxis
field_name = models.BinaryField(**options)
Django Modelo BinaryField Explicación
Ilustración de BinaryField utilizando un ejemplo. Considere un proyecto llamado geeksforgeeks que tenga una aplicación llamada geeks.
Consulte los siguientes artículos para comprobar cómo crear un proyecto y una aplicación en Django.
Ingrese el siguiente código en el archivo models.py de la aplicación geeks .
Python3
from django.db import models from django.db.models import Model # Create your models here. class GeeksModel(Model): geeks_field = models.BinaryField()
Agregue la aplicación geeks a INSTALLED_APPS
Python3
# Application definition INSTALLED_APPS = [ 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'geeks', ]
Ahora, cuando ejecutamos el comando makemigrations desde la terminal,
Python manage.py makemigrations
Se crearía una nueva carpeta llamada migraciones en el directorio geeks con un archivo llamado 0001_initial.py
Python3
# Generated by Django 2.2.5 on 2019-09-25 06:00 from django.db import migrations, models class Migration(migrations.Migration): initial = True dependencies = [ ] operations = [ migrations.CreateModel( name ='GeeksModel', fields =[ ('id', models.AutoField(auto_created = True, primary_key = True, serialize = False, verbose_name ='ID' )), ('geeks_field', models.BinaryField()), ], ), ]
Por lo tanto, se crea un geeks_field BigIntegerField cuando ejecuta makemigrations en el proyecto. Es un campo para almacenar datos binarios sin procesar.
¿Cómo usar BinaryField?
Cualquier tipo de datos se puede convertir en bytes, incluidos números enteros, strings, imágenes, etc. Intentemos guardar una string en BinaryField. La string se puede convertir en bytes utilizando la función de bytes genéricos. Esta función apunta internamente a la biblioteca de CPython, que implícitamente llama a la función de codificación para convertir la string a la codificación especificada.
Python3
# importing the model # from geeks app from geeks.models import GeeksModel # creating a string test_string = "GFG is best" # creating a bytes object res = bytes(test_string, 'utf-8') # creating a instance of # GeeksModel geek_object = GeeksModel.objects.create(geeks_field = res) geek_object.save()
Ahora vamos a comprobarlo en el servidor de administración. Hemos creado una instancia de GeeksModel
Posibles errores
Como se especifica, BinaryField es un campo no editable, si intenta manualmente hacerlo editable usando editable=True, creará errores inesperados. Debe crearse en una función para que se le puedan asignar objetos.
Opciones de campo
Las opciones de campo son los argumentos dados a cada campo para aplicar alguna restricción o impartir una característica particular a un campo en particular. Por ejemplo, agregar un argumento null = True a BinaryField le permitirá almacenar valores vacíos para esa tabla en la base de datos relacional.
Aquí están la opción y los atributos que puede usar un BinaryField.
Opciones de campo | Descripción |
---|---|
Nulo | Si es True , Django almacenará valores vacíos como NULL en la base de datos. El valor predeterminado es Falso . |
Vacío | Si es True , el campo puede estar en blanco. El valor predeterminado es Falso . |
columna_db | El nombre de la columna de la base de datos que se usará para este campo. Si no se proporciona, Django usará el nombre del campo. |
Defecto | El valor predeterminado para el campo. Puede ser un valor o un objeto invocable. Si es invocable, se llamará cada vez que se cree un nuevo objeto. |
texto de ayuda | Texto adicional de «ayuda» que se mostrará con el widget de formulario. Es útil para la documentación incluso si su campo no se usa en un formulario. |
Clave primaria | Si es Verdadero, este campo es la clave principal para el modelo. |
editable | Si es False , el campo no se mostrará en el administrador ni en ningún otro ModelForm. También se omiten durante la validación del modelo. El valor predeterminado es Verdadero . |
error de mensajes | El argumento error_messages le permite anular los mensajes predeterminados que generará el campo. Pase un diccionario con claves que coincidan con los mensajes de error que desea anular. |
texto de ayuda | Texto adicional de «ayuda» que se mostrará con el widget de formulario. Es útil para la documentación incluso si su campo no se usa en un formulario. |
nombre_verbose | Un nombre legible por humanos para el campo. Si no se proporciona el nombre detallado, Django lo creará automáticamente utilizando el nombre del atributo del campo, convirtiendo los guiones bajos en espacios. |
validadores | Una lista de validadores para ejecutar para este campo. Consulte la documentación de los validadores para obtener más información. |
Único | Si es Verdadero, este campo debe ser único en toda la tabla. |
Publicación traducida automáticamente
Artículo escrito por NaveenArora y traducido por Barcelona Geeks. The original can be accessed here. Licence: CCBY-SA