DateTimeField – Modelos de Django

DateTimeField es un campo de fecha y hora que almacena la fecha, representada en Python por una datetime.datetimeinstancia. Como sugiere el nombre, este campo se usa para almacenar un objeto de fecha y hora creado en python. El widget de formulario predeterminado para este campo es un archivo TextInput. El administrador usa dos TextInputwidgets separados con accesos directos de JavaScript.

Sintaxis

field_name = models.DateTimeField(**options)
DateTimeField tiene los siguientes argumentos opcionales adicionales:
  • DateTimeField.auto_ahora

    Establece automáticamente el campo ahora cada vez que se guarda el objeto. Útil para las marcas de tiempo de «última modificación». Tenga en cuenta que siempre se utiliza la fecha actual; no es solo un valor predeterminado que puede anular.
    El campo solo se actualiza automáticamente cuando se llama a Model.save() . El campo no se actualiza cuando se actualizan otros campos de otras formas, como QuerySet.update() , aunque puede especificar un valor personalizado para el campo en una actualización como esa.

  • DateTimeField.auto_now_add

    Establece automáticamente el campo ahora cuando se crea el objeto por primera vez. Útil para la creación de marcas de tiempo. Tenga en cuenta que siempre se utiliza la fecha actual; no es solo un valor predeterminado que puede anular. Por lo tanto, incluso si establece un valor para este campo al crear el objeto, se ignorará. Si desea poder modificar este campo, configure lo siguiente en lugar de auto_now_add=True:

    • Para DateTimeField: predeterminado=datetime.now – desdedatetime.now()
    • Para DateTimeField: default=timezone.now – desdedjango.utils.timezone.now()

Nota : Las opciones auto_now_add, auto_now y default son mutuamente excluyentes. Cualquier combinación de estas opciones dará como resultado un error.

Django Modelo DateTimeField Explicación

Ilustración de DateTimeField utilizando un ejemplo. Considere un proyecto llamado geeksforgeeksque tiene 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 models.pyel archivo de la aplicación geeks .

from django.db import models
from django.db.models import Model
# Create your models here.
  
class GeeksModel(Model):
    geeks_field = models.DateTimeField()

Agregue la aplicación geeks aINSTALLED_APPS

# 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 makemigrationsel comando desde la terminal,

Python manage.py makemigrations

Se crearía una nueva carpeta llamada migraciones en el geeksdirectorio con un archivo llamado0001_initial.py

# 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.DateTimeField()),
            ],
        ),
    ]

Ahora corre,

Python manage.py migrate

Por lo tanto, se crea un geeks_field DateTimeField cuando ejecuta migraciones en el proyecto. Es un campo para almacenar datetime.datetimeobjetos de python.

¿Cómo usar DateTimeField?

DateTimeField se usa para almacenar la instancia de python datetime.datetime en la base de datos. Uno puede almacenar cualquier tipo de fecha y hora utilizando el mismo en la base de datos. Intentemos almacenar una fecha en el modelo creado anteriormente.

# importing the model
# from geeks app
from geeks.models import GeeksModel
  
# importing datetime module
import datetime
  
# creating an instance of 
# datetime.date
d = datetime(2015, 10, 09, 23, 55, 59, 342380)
  
# creating an instance of 
# GeeksModel
geek_object = GeeksModel.objects.create(geeks_field = d)
geek_object.save()

Ahora vamos a comprobarlo en el servidor de administración. Hemos creado una instancia de GeeksModel.
DateTimeField django models

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 = Truea DateTimeField le permitirá almacenar valores vacíos para esa tabla en la base de datos relacional.
Estas son las opciones de campo y los atributos que puede usar un DateTimeField.

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

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *