Как преобразовать pandas datetime64 во что-то, что может быть распознано как DateField в Django?
Когда я загружаю Excel с помощью pandas, столбец, содержащий даты, был правильно определен как datetime64
excel_table = pd.read_excel(path, sheet_name=ws_name, header=2)
print(excel_table['Start Date'])
# output:
0 2001-01-31
1 2001-03-02
2 2001-07-23
3 2001-07-25
4 2002-03-11
...
Name: Start Date, Length: 11056, dtype: datetime64[ns]
Затем я написал excel_table
в базу данных sqlite3:
excel_table.to_sql(table_name, cols_to_use, index=False)
Когда я проверяю столбцы, используя PRAGMA table_info(TABLENAME)
, я получаю следующее:
...
11|Start Date|NUM|0||0
...
Разве это не должно быть TIMESTAMP
, а не NUM
?
Затем я создал класс модели, используя метод Django inspectdb
, который дал мне следующее:
# This is an auto-generated Django model module.
# You'll have to do the following manually to clean this up:
# * Rearrange models' order
# * Make sure each model has one field with primary_key=True
# * Make sure each ForeignKey and OneToOneField has `on_delete` set to the desired behavior
# * Remove `managed = False` lines if you wish to allow Django to create, modify, and delete the table
# Feel free to rename the models, but don't rename db_table values or field names.
from django.db import models
class TableName(models.Model):
start_date = models.TextField(db_column='Start Date', blank=True, null=True) # Field name made lowercase. Field renamed to remove unsuitable characters. This field type is a guess.
class Meta:
managed = False
db_table = 'TableName'
Теперь это TextField
, а не DateField
, что проблематично, поскольку я пытаюсь реализовать функции фильтрации и сортировки для этого столбца (например, фильтрация дат после 2020-12-31 и т.д.).
Где я допустил ошибки, и как мне это исправить?
В файле models.py объявите поле start_date
как DateField
(или DateTimeField
)
datetime64
dtype датафрейма будет автоматически преобразован в исправленный тип в MySQL или SQLite.
В файле serializers.py добавьте следующую строку:
from rest_framework import serializers
start_date = serializers.DateTimeField(format="%Y-%m-%d")
Старый ответ:
Возможно, вы можете попробовать преобразовать datetime64
в python datetime и экспортировать в базу данных:
df['Start Date'] = df['Start Date'].dt.to_pydatetime()