アプリケーションをdjango 1.2から1.4に移行中です。
タスクを完了する必要がある時刻を含む毎日のタスク オブジェクトがあります。
class DailyTask(models.Model):
time = models.TimeField()
last_completed = models.DateTimeField()
name = models.CharField(max_length=100)
description = models.CharField(max_length=1000)
weekends = models.BooleanField()
def __unicode__(self):
return '%s' % (self.name)
class Meta:
db_table = u'dailytask'
ordering = ['name']
タスクを今日完了する必要があるかどうかを確認するために、次のコードがあります。
def getDueDailyTasks():
dueDailyTasks=[]
now = datetime.datetime.now()
try:
dailyTasks = DailyTask.objects.all()
except dailyTask.DoesNotExist:
return None
for dailyTask in dailyTasks:
timeDue = datetime.datetime(now.year,now.month,now.day,dailyTask.time.hour,dailyTask.time.minute,dailyTask.time.second)
if timeDue<now and timeDue>dailyTask.last_completed:
if dailyTask.weekends==False and now.weekday()>4:
pass
else:
dueDailyTasks.append({'id':dailyTask.id,
'due':timeDue,
'name': dailyTask.name,
'description':dailyTask.description})
return dueDailyTasks
これは 1.2 では問題なく動作しましたが、1.4 では次のエラーが発生します。
can't compare offset-naive and offset-aware datetimes
ラインのせい
if timeDue<now and timeDue>dailyTask.last_completed
両方の比較句がこのエラーをスローします。
pytz.UTC を引数として追加して timeDue タイムゾーンを認識させようとしましたが、それでも同じエラーが発生します。
タイムゾーンに関するいくつかのドキュメントを読みましたが、timeDue タイムゾーンを認識させる必要があるだけなのか、それともデータベースと既存のデータに根本的な変更を加える必要があるのか について混乱しています。