我创建了一个namedtuple并用它来跟踪单个数据集。当我添加一个新的"数据点"对于namedtuple,print()函数显示我没有相同的确切信息。这是一个例子:
from collections import namedtuple
bbnr = namedtuple('bbnr', ['SN', 'ptr', 'type2'])
DVCS = bbnr('AB01', 101, 'bbnr')
DVCS_b = [DVCS]
print(DVCS_b) # produces [bbnr(SN='AB01', ptr=101, type2='bbnr')]
DVCS = DVCS, bbnr('AB02', 105, 'bbnr')
DVCS_b = [DVCS]
print(DVCS_b) # [(bbnr(SN='AB01', ptr=101, type2='bbnr'), bbnr(SN='AB02', ptr=105, type2='bbnr'))]
请注意,在第二个打印输出中,括号内的整个元组周围有一组额外的括号()。
如何将新元素添加到namedtuple?
答案 0 :(得分:1)
您的问题与命名元组无关;你正在创造那些就好了。
相反,你在这里创建了一个元组:
DVCS = DVCS, bbnr('AB02', 105, 'bbnr')
注意逗号;元组由逗号定义,而不是括号:
>>> 1
1
>>> 1,
(1,)
>>> 1, 2
(1, 2)
然后将该元组包装到列表对象中。
如果您想要这些值的列表,那么只需创建列表:
DVCS_b = [DVCS, bbnr('AB02', 105, 'bbnr')]
或创建没有DVCS
值的新命名元组,并从现有列表中获取先前命名的元组:
DVCS = bbnr('AB02', 105, 'bbnr')]
DVCS_b = DVCS_b + [DVCS]
或将其附加到现有列表中:
DVCS = bbnr('AB02', 105, 'bbnr')]
DVCS_b.append(DVCS)