【python】AttributeError: ‘int‘ object has no attribute ‘xxx‘问题解决

一、问题

在执行代码时遇到了: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类型,最后慢慢定位出错误。

  • 5
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

暗夜无风

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值