我可以使用变量的值作为函数的参数名吗?

时间:2016-05-03 21:27:47

标签: python parameters expression parameter-passing

有很多StackOverflow问题要求将变量用作变量(例如thisthis,但我认为这不是重复的那些。我想知道我是否可以将变量的值用作函数参数。

例如,假设我想调用一个函数来填充两个不同的MySQL表中的一个:

  • 名称表的列为idfullname
  • 手机表的列为idphonenum
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()不在我的控制之下 - 它将接受dateid以及phonenumfullname参数,但不能重构。)

1 个答案:

答案 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})