我正在使用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'无法回答我的问题
答案 0 :(得分:1)
您正在使用的数据库可能包含无法解析的日期时间,或者在从游标读取数据时无法正确处理该日期时间。 Peewee会自动尝试将字符串datetime值转换为适当的python datetime实例,但是如果表中有垃圾或格式怪异的数据,它将无法正常工作。
这通常仅是sqlite数据库的问题,因为其他数据库将强制将有效的datetime存储在datetime-affinity列中。
您可以尝试通过扩展相关字段的受支持格式来解决此问题。例如DateTimeField
包含将自动解析的格式列表(field.formats)。您可以扩展它以包括您使用的任何格式。