有很多StackOverflow问题要求将变量用作变量(例如this和this,但我认为这不是重复的那些。我想知道我是否可以将变量的值用作函数参数。
例如,假设我想调用一个函数来填充两个不同的MySQL表中的一个:
id
和fullname
。id
和phonenum
data = get_data() # data = a full name or a phone number
data_type = get_data_type(data) # data_type = "name" or "phone"
....
column_names_for_tables = {'name': 'fullname', 'phone': 'phonenum'}
column_name = column_names_for_tables[data_type]
# column_name now = "fullname" or "phonenum", depending on the value of #data
new_entry = MakeNewEntry(date=datetime.datetime.now(), id=123, <column_name>=data)
当然最后一行不是有效的Python,但我的目标是动态生成函数调用:
new_entry = MakeNewEntry(date=datetime.datetime.now(), id=123, fullname=data)
或
new_entry = MakeNewEntry(date=datetime.datetime.now(), id=123, phonenum=data)
也就是说,我想使用column_name
的值作为参数的名称。
我能这样做吗?
(对于此示例,请假设MakeNewEntry()
不在我的控制之下 - 它将接受date
,id
以及phonenum
或fullname
参数,但不能重构。)
答案 0 :(得分:2)
您可以使用double star operator将任意参数传递给函数:
col = 'foo'
val = 'bar'
kwargs = {col: bar}
some_function(**kwargs)
你可以通过内联字典来缩短它:
some_function(**{col: var})
你可以混合和匹配语法,最后得到这样的结果:
MakeNewEntry(date=datetime.datetime.now(), id=123, **{column_name: data})