gpt4 book ai didi

python - 你能在 python 中循环创建类吗?

转载 作者:行者123 更新时间:2023-12-04 03:41:57 26 4
gpt4 key购买 nike

我有一种情况,我正在制作一堆类,其中一堆基本上是相同的,所以我想让它们循环。它们与注册系统一起使用,因此在 USAGE 方面没有问题,但我不确定如何使用确定类名的变量实际定义类...

简单的例子:

classList = ['foo', 'bar', 'baz']

for className in classList:
class {{{className}}}_calc(BaseCalc):
def __init__ (self, dataFrame):
self.column = dataFrame[className]
def calc ():
return self.column.sum()

显然,这是一个非常简化的案例。我无法更改 init 的参数,因为已经存在一大堆参数,它们是更大结构的一部分。

示例的其余部分使用了 pandas 语法,只是为了了解它是如何使用的……但它实际上是与 SQL DB 一起使用的,而且要复杂得多……我只是不知道想要捍卫“你为什么首先要这样做?”我有充分的理由,就这样吧。

classname 在 class 行的 {{{ }}} 中表示它是一个变量,实际上在语法上并不正确。问题是“我如何表示我使用 {{{ }}} 的目的?”我想。

答案可能是元类,但我仍然不确定如何制作我的类变量的名称....

预计到达时间:尝试使用@python_user 回答:

classList = ['foooo', 'bar', 'baaz']

class Base ():
def __init__ (self, buq):
self.buq = buq

def getBuq(self):
return 'buq: ' + self.buq


for cls in classList:
class TEMP(Base):
className = cls
def __init__ (self):
self.qux = len(cls)
Base.__init__(self, cls)

def blee(self, inpt):
return inpt+ self.qux
TEMP.__name__ = f'{cls}'
TEMP.__qualname__ = f'{cls}'
globals()[cls] = TEMP
f = foo()

f.getBuq()

>>>> 'buq: baaz'

这只是给我 baaz 类。这三个人都在胡闹……我是不是在做一些非常愚蠢的事情?

最佳答案

你可以这样做,使用 globals()

classList = ['foo', 'bar', 'baz']

for className in classList:
class Temp:
def __init__ (self, dataFrame):
self.column = dataFrame[className]
def calc ():
return self.column.sum()
Temp.__name__ = className
globals()[className] = Temp

然后您可以执行 foo() 来创建类 foo 的对象。对于实际示例,您必须调用 __init__ 方法所需的参数。这只是为了证明它有效。

print(type(foo()).__name__) # foo
print(type(bar()).__name__) # bar
print(type(baz()).__name__) # baz

如果你想改变你的类名,那么你可以这样做

Temp.__name__ = f'{className}_calc'
globals()[f'{className}_calc'] = Temp

正如 wim 在评论中指出的,您还需要设置 __qualname__Temp.__qualname__ = f'{className}_calc'

编辑:

由于类的方法中的名称查找是在运行时(而非编译时)执行的,因此代码片段存在一个错误。 className 将始终引用 classList 中的最后一个元素(在本例中为 baz),该名称存在于循环范围之外,并将是所有类的方法中 className 的值。 (例如:self.column = dataFrame[className])。 <--- 这总是 dataFrame['baz']

要解决此问题,必须声明一个名为 className 的类级变量并将 className(循环中的变量)分配给它。所以在编译时这个值将被绑定(bind)到类。类方法中对 className 的所有引用都需要更改为 self.className 以使代码按预期工作。

class Temp:
className = className # note this line
def __init__ (self, dataFrame):
self.column = dataFrame[self.className] # and this line with the original snippet

关于python - 你能在 python 中循环创建类吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65888722/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com