我正在使用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模块以使其工作......至少)
答案 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')