一、问题
在执行代码时遇到了:AttributeError: 'int' object has no attribute 'filterNode'的问题,代码如下:
for cludId, node in enumerate(clusters):
selectSql = "SELECT\n"
for i, field in enumerate(node.filterNode.fieldList):
if i != 0:
selectSql = selectSql + ",\n"
selectSql = selectSql + "\t" + field
fromSql = "\nFROM\n"
for i, table in enumerate(node.filterNode.tableList):
if i != 0:
fromSql = fromSql + ",\n"
fromSql = fromSql + "\t" + table
whereSql = "\nWHERE\n "
for i, filter in enumerate(node.filterNode.filterList):
if i != 0:
whereSql = whereSql + "\n\tAND"
whereSql = whereSql + " " + filter
sql = selectSql + fromSql + whereSql
# 输出sql
filename = "mv" + str(cludId) + ".sql"
with open(mvPath + "/sql/" + filename, "w", encoding="utf-8") as f:
f.write(sql)
而从字面上意思,就是int类型的对象没有filterNode参数,定位到代码:for i, field in enumerate(node.filterNode.fieldList):这里,也就是说node类型可能不是我们想要的node类型。
这时候我通过调试发现,node居然等于。

所以很明显,问题出在第一行代码:for cludId, node in enumerate(clusters):,而这看不错问题所在,因为enumerate正常遍历list类型,但是问题正好出在这,从刚才的调试结果发现clusters其实是dict类型,而dict类型不能用enumerate来遍历,所以这就是问题所在,误用enumerate导致解析出的node是int类型的0,从而出现错误。
解决方式也很简单,使用items()遍历:
for cludId, node in clusters.items():
二、反思
其实在问题刚开始出现的时候,是有点摸不着头脑的,因为node很明显是个对象为何没有其属性。但是通过调试发现node是int类型,最后慢慢定位出错误。
本文记录了一次遇到AttributeError问题的解决过程。在执行Python代码时,由于误用enumerate遍历了字典clusters,导致node被解析为int类型,引发错误。解决方案是将enumerate改为clusters.items()来正确遍历字典。通过调试,作者成功定位并解决了问题,提醒开发者注意类型检查和遍历操作的准确性。

2万+

被折叠的 条评论
为什么被折叠?



