我试图从我在单独的python文件中创建的对象访问属性。
我尝试了以下代码:
print(self.GENOME[0][0].x)
其中self.GENOME[0][0]
是对象内存地址。
但是,我得到
AttributeError:“设置”对象没有属性“ x”
agent.py:
import neuron
#Creates an array of custom shape (3,4,3) and assigns unique object
#address
for ii in range(len(_Topology)):
_Genome[ii] = [{neuron.Neuron()} for i in range(_Topology[ii]+1)]
#Calls object variable
print(self.GENOME[0][0].x)
neuron.py:
class Neuron:
def __init__(self):
self.x = 50
答案 0 :(得分:0)
_Genome[ii]
包含一个列表,该列表至少包含Neuron
个实例的集合。简化一下,您可以像这样:
>>> a = [{Neuron()} for _ in [1,2]]
>>> a
[{<__main__.Neuron object at 0x0000000002CAFF28>}, {<__main__.Neuron object at 0x0000000002CAFF60>}]
>>> q = [a]
>>> q
[[{<__main__.Neuron object at 0x0000000002CAFF28>}, {<__main__.Neuron object at 0x0000000002CAFF60>}]]
>>>
如果打印_Genome
,它将看起来像这样-我假设_Genome
是 list-like |上面的q
应该类似于_Genome
。
建立索引看起来像这样
>>> q[0]
[{<__main__.Neuron object at 0x0000000002CAFF28>}, {<__main__.Neuron object at 0x0000000002CAFF60>}]
>>> type(q[0])
<class 'list'>
>>> q[0][0]
{<__main__.Neuron object at 0x0000000002CAFF28>}
>>> type(q[0][0])
<class 'set'>
>>>
设置行为为well documented-与大多数Python一样。
一种访问集合内容的方法是使用for循环
>>> for thing in q[0][0]:
print(thing.x)
50
>>>
访问集合内容的另一种方法是使用pop()
方法,但这将从集合中删除任意项。我不认为您真的想要这个-如果有一个以上的项目,而原始集却少一个项目,您将无法控制获得的项目。
>>> x = [[{Neuron()},{Neuron}]]
>>> t = x[0][0].pop()
>>> t
<__main__.Neuron object at 0x0000000002C2F2E8>
>>> t.x
50
>>> x
[[set(), {<class '__main__.Neuron'>}]]
>>>
您还可以从集合中创建一个列表,并使用索引来访问列表的内容。
>>> q
[[{<__main__.Neuron object at 0x0000000002CAFF28>}, {<__main__.Neuron object at 0x0000000002CAFF60>}]]
>>> z = list(q[0][0])
>>> z
[<__main__.Neuron object at 0x0000000002CAFF28>]
>>> z[0].x
50
>>>
所有这些似乎都太复杂了,最好更改包含Neuron
实例的方式。我不知道这对您是否可行。只需取消包含单个实例的集合:
>>> a = [Neuron() for _ in [1,2]]
>>> a
[<__main__.Neuron object at 0x0000000002C2FDD8>, <__main__.Neuron object at 0x0000000002CD00B8>]
>>> q = [a]
>>> q[0][0]
<__main__.Neuron object at 0x0000000002C2FDD8>
>>> type(q[0][0])
<class '__main__.Neuron'>
>>> q[0][0].x
50
>>>