指定从表达式中获取的对象名称

时间:2012-11-17 22:26:32

标签: python

我需要从外部源提取数据。我建立了一些具有某种结构的基础链。我需要类型为myBase类的对象,但其名称会自动描述迭代源的次数。我构建了一个存储这个数字的类,并使用一个call方法返回我需要的对象。我找不到将字符串作为对象名称的方法,但每次构建新对象时都会自动不同。 我简化了这个例子的代码:

class myBase:
    def __init__(self):
        iteratedValue = None

class myIterator:
    def __init__(self):
        self.k = 0
    def __call__(self, s):
        self.k += 1
        self.name = 'myData' + str(self.k)
        # create an object named myData1, myData2 ...
        self.name = myBase() 
        self.name.iteratedValue = s 
        print '%s name is %s for k = %i' % (self.name, self.name.iteratedValue, self.k)

        # return object named myData1 type of myBase
        return self.name

def DataExtraction():
    # function to extract data form external source
    data = myIterator()
    data('Alice') 
    data('Ben') 

DataExtraction()

我的输出是:

<__main__.myBase instance at 0x7f261b6dc6c8> name is Alice for k = 1
<__main__.myBase instance at 0x7f261b6dc6c8> name is Ben for k = 2

我需要返回一个具有特定名称的对象,我希望输出:

myData1 name is Alice for k = 1
myData2 name is Ben for k = 2

原始问题要复杂得多。我有外部数据,每次他们来我想从这些数据中提取一些值。每次我这样做,我需要一个对象来处理它,但我需要这个具有不同名称的对象,因为最后我将它们存储在dict中用于另一种方法。换句话说,我处理数据并将结果存储在对象myData1中,当原始数据更改时我再次使用它并将结果存储在myData2等等。毕竟我需要所有{{1}对象并对它们进行统计,看看如何改变。我无法访问原始数据。我需要myData的自动名称约定,如果它表示迭代器,则需要最好。

如何使用字符串代替myData作为对象的名称?

3 个答案:

答案 0 :(得分:3)

看起来你最好使用发电机。下面是一些读取数据的示例代码(实际上它就像在您的示例中一样是硬编码的),然后使用索引名称构造Datum对象。

class Datum(object):
    def __init__(self, index, value):
        self.name = 'myData%d' % (index + 1)
        self.value = value

def read_data():
    yield 'Alice'
    yield 'Ben'

def enumerate_data():
    for i, value in enumerate(read_data()):
        yield Datum(i, value)

for d in enumerate_data():
    print d.name, d.value

答案 1 :(得分:2)

您已经使用self.name = 'myData' + str(self.k)进行了此操作。问题是你立即用self.name = myBase()覆盖它。我不确定你要用myBase()做什么,但你可能想把它与名字分开。 self.name可以是字符串或myBase对象,但不能同时包含这两个对象。

也许你可以这样做:

    self.name = 'myData' + str(self.k)
    self.base= myBase() 
    self.base.iteratedValue = s 
    print '%s name is %s for k = %i' % (self.name, self.baseiteratedValue, self.k)

通过这种方式,您可以同时使用名称和“基础”作为单独的属性self.nameself.base

或者,您可以为myBase类提供__str__方法。这会影响在print对象上使用myBase时显示的内容。但是,要实现这一点,您必须在实例化myBase时传递所需的名称,例如:

class myBase(object):
    def __init__(self, name, iteratedValue):
        self.name = name
        iteratedValue = iteratedValue
    def __str__(self):
        return self.name

class myIterator(object):
    def __init__(self):
        self.k = 0
    def __call__(self, s):
        self.k += 1
        name = 'myData' + str(self.k)
        self.name = myBase(name, s) 
        print '%s name is %s for k = %i' % (self.name, self.name.iteratedValue, self.k)

        # return object named myData1 type of myBase
        return self.name

我不确定您正在寻找的是哪种方式(或者其他方式)。令人费解的是,您正在使对象的“名称”成为myBase实例。我不确定您想要表示对象的“名称”是什么,但我通常不希望对象的名称成为其他对象。

顺便说一句,看起来您正在使用Python 2,在这种情况下,您应该使用class someClass(object)定义您的类。包括object使你的类成为新式的类,这基本上就是你想要的。

编辑:如果你要做的事实上是根据字符串创建一个名为myData1的变量,那么你可以myData('Alice')然后以某种方式神奇地拥有变量myData1参考那个对象,答案是“不要那样做”。如果您想创建一堆对象并通过数字或其他标签以结构化方式访问它们,请使用列表或字典。

答案 2 :(得分:0)

为什么要担心命名对象,为什么不把它们放在dict

myObjects = {1:Alice(), 2:Bob()}