获取“ str”对象的peewee DateTimeField没有属性“ isoformat”

时间:2019-12-18 11:48:03

标签: python peewee

我正在使用peewee ORM从MySQL数据库读取数据。我的数据库模型类如下

import peewee
import datetime
from collections import OrderedDict
...............

class User(peewee.Model):
...............

    created_by = CharField(null=True)
    update_by = CharField(null=True)
    updated_date = DateTimeField(default=datetime.datetime.now)
.................

    def __to_dict__(self):
        user_dict = OrderedDict([
.................
            ('created_by', self.created_by),
            ('update_by', self.update_by),
            ('updated_date', self.updated_date.isoformat())
        ])
.............

我正在使用以下代码从ORM设置数据

users= User.select().distinct()
return [user.__to_dict__() for user in users]

对于某些更新了日期字段为'0000-00-00 00:00:00'的数据行,我遇到以下错误

 user = user.__to_dict__()
File "/opt/appserver/app1/app/models/user.py", line 172, in __to_dict__
('updated_date', self.updated_date.isoformat())
AttributeError: 'str' object has no attribute 'isoformat'

为什么我会收到此错误?

PS:AttributeError: 'str' object has no attribute 'isoformat'无法回答我的问题

1 个答案:

答案 0 :(得分:1)

您正在使用的数据库可能包含无法解析的日期时间,或者在从游标读取数据时无法正确处理该日期时间。 Peewee会自动尝试将字符串datetime值转换为适当的python datetime实例,但是如果表中有垃圾或格式怪异的数据,它将无法正常工作。

这通常仅是sqlite数据库的问题,因为其他数据库将强制将有效的datetime存储在datetime-affinity列中。

您可以尝试通过扩展相关字段的受支持格式来解决此问题。例如DateTimeField包含将自动解析的格式列表(field.formats)。您可以扩展它以包括您使用的任何格式。