MaterialInventory 类是用来记录每天消耗的,想法是每天更新一次数据,把当前数据更新到数据库,以下是构造函数
def __init__(self, remain_electricity, remain_air, remain_welding_wire,day=datetime.date.today()):
    self.remain_air = remain_air
    self.remain_electricity = remain_electricity
    self.remain_welding_wire = remain_welding_wire
    self.date  = day 

每天检查有没有数据,没有数据则更新

materialStock = MaterialInventory.query.filter(MaterialInventory.date == date.today().strftime(\'%Y-%m-%d\')).first()
if not materialStock:
    UpdateStock()

 

def UpdateStock():
    materialStock = MaterialInventory(materialStockYesterday.remain_electricity,
                                          materialStockYesterday.remain_air,
                                         materialStockYesterday.remain_electricity)
    materialStock.save()

想法很好,但是发现服务器运行到第二天凌晨过后就报错,查数据库发现每次都新增了昨日数据,没有最新一天的。

最终发现是构造函数中默认参数的问题,程序启动的时候就已经把day的值算好写死了,如果参数缺省就会用固定值,不会随着时间datetime更新了。

 

收藏 打印