鱼C论坛

 找回密码
 立即注册
查看: 1760|回复: 2

[已解决]请大家看看代码时哪里出错啦?

[复制链接]
发表于 2023-6-9 13:48:48 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
import tkinter


def get_bases(cls, count=0):
    for i in range(count):
        print('-', end=' ')
    print(cls)

    if cls.__base__[0] is not object:
        for each in cls.__base__:
            get_bases(each, count)
            count -= 1

get_bases(tkinter.Text)
tkinter.Text.mro()

出错信息:
Traceback (most recent call last):
  File "……", line 14, in <module>
    get_bases(tkinter.Text)
  File "……", line 9, in get_bases
    if cls.__base__[0] is not object:
TypeError: 'type' object is not subscriptable
<class 'tkinter.Text'>


上面的代码是按照老师的代码写出来的,但是一运行就出错,不知道为什么?
请教大家看看为什么出错啦,如何修改呢?


正确的运行结果如下图:


                               
登录/注册后可看大图


最佳答案
2023-6-9 13:50:29
问题出在这一行代码:
if cls.__base__[0] is not object:

在Python中, __base__ 属性返回一个类的基类,它返回的是一个类,而不是类的列表。所以当你尝试索引一个类时,Python会抛出一个TypeError,因为'类对象是不可索引的'。从你的代码看,你可能是想获取该类的所有基类。

如果你想获取一个类的所有基类,你应该使用 __bases__ ,而不是 __base__ 。 __bases__ 是一个元组,包含了该类所有的直接父类。

修改后的代码如下:
import tkinter

def get_bases(cls, count=0):
    for i in range(count):
        print('-', end=' ')
    print(cls)

    if cls.__bases__:  # 注意这里改为了__bases__
        for each in cls.__bases__:  # 这里也改为了__bases__
            get_bases(each, count + 1)  # 这里需要+1,而不是-1,因为你是在更深的层次,所以应该增加缩进。

get_bases(tkinter.Text)

print(tkinter.Text.mro())

这样你的代码就不会抛出错误,并且会按预期的方式运行了。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-6-9 13:50:29 | 显示全部楼层    本楼为最佳答案   
问题出在这一行代码:
if cls.__base__[0] is not object:

在Python中, __base__ 属性返回一个类的基类,它返回的是一个类,而不是类的列表。所以当你尝试索引一个类时,Python会抛出一个TypeError,因为'类对象是不可索引的'。从你的代码看,你可能是想获取该类的所有基类。

如果你想获取一个类的所有基类,你应该使用 __bases__ ,而不是 __base__ 。 __bases__ 是一个元组,包含了该类所有的直接父类。

修改后的代码如下:
import tkinter

def get_bases(cls, count=0):
    for i in range(count):
        print('-', end=' ')
    print(cls)

    if cls.__bases__:  # 注意这里改为了__bases__
        for each in cls.__bases__:  # 这里也改为了__bases__
            get_bases(each, count + 1)  # 这里需要+1,而不是-1,因为你是在更深的层次,所以应该增加缩进。

get_bases(tkinter.Text)

print(tkinter.Text.mro())

这样你的代码就不会抛出错误,并且会按预期的方式运行了。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-6-9 14:06:13 | 显示全部楼层
isdkz 发表于 2023-6-9 13:50
问题出在这一行代码:


谢谢您,是我粗心,少写了s,原来的代码是这样。。
import tkinter


def get_bases(cls, count=0):
    for i in range(count):
        print('-', end=' ')
    print(cls)

    if cls.__bases__[0] is not object:
        for each in cls.__bases__:
            count += 1
            get_bases(each, count)
            count -= 1

get_bases(tkinter.Text)
print(tkinter.Text.mro())

非常感谢您。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-9-22 21:32

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表