最近在写代码是遇到了一个问题,是debug与run时出现结果不一致的问题。
通过print大法发现了一些端倪。
问题代码:
rank_data = []
for i in rank_count:
team = []
team = SystemUser.objects.filter(staff_num=i).values("team", "name") # 数据格式:《》
team[0].update({"score": rank_count[i]})
print("-----", rel_team, rank_count[i])
rank_data.append(team[0])
print("最后的rank数据", rank_data)
修改后的代码:
rank_data = []
for i in rank_count:
team = []
team = SystemUser.objects.filter(staff_num=i).values("team", "name")
rel_team = team[0] # 增加了这一句话
rel_team.update({"score": rank_count[i]})
print("-----", rel_team, rank_count[i])
rank_data.append(rel_team)
print("最后的rank数据", rank_data)
在问题代码中通过print排查,发现下面这个语句执行前,执行后,team[0]的值没有任何变化。所以在执行前为team[0]新创建了一个变量,再进行update操作。然后run的时候update就执行成功了。
team[0].update({"score": rank_count[i]})
问题代码:程序在debug和run时的结果是不同的。在debug时,update操作是能够成功执行的,但是run的时候,update是失效的。所以推测,在debug时,能够对team[0]初始化,为其进行updata操作;而run的时候不会,所以update失败。



