从元组创建命名元组?

时间:2017-02-13 23:39:24

标签: python tuples kinterbasdb

我正在使用kinterbasdb从1998年的数据库中选择和更新一些数据(是的,不幸的是:()。而kinterbasdb的API返回元组中查询的值,例如:

connection = connect(dsn="database.gdb", user="MYUSER", password="MYPASSWORD")
cursor = connection.cursor()
cursor.execute("SELECT * FROM TABLE_X")
result = cursor.fetchone() # tuple => (value1, value2, value3, value4, value5)

我想将这个元组映射到一个命名的元组。有可能吗?

我正在使用Python 2.7.13(我能够更新kinterbasdb模块以使其工作......至少)

2 个答案:

答案 0 :(得分:1)

使用*将您的元组作为扩展的args传递给namedtuple构造函数。

In [1]: from collections import namedtuple

In [2]: Response = namedtuple('Response', ['thing1', 'thing2', 'thing3', 'thing4'])

In [3]: mytuple = (1, 2, 3, 4)

In [4]: Response(*mytuple)
Out[4]: DBResponse(thing1=1, thing2=2, thing3=3, thing4=4)

答案 1 :(得分:0)

示例:

from collections import namedtuple
t=("value1", "value2", "value3", "value4", "value5")
Data=namedtuple("Data",["v1","v2","v3","v4","v5"])
nt=Data(*t)
>>> nt
Data(v1='value1', v2='value2', v3='value3', v4='value4', v5='value5')

或使用_make方法:

>>> Data._make(t)
Data(v1='value1', v2='value2', v3='value3', v4='value4', v5='value5')