Dynamic Keyword Arguments in Python?

Python

Python Problem Overview


Does python have the ability to create dynamic keywords?

For example:

qset.filter(min_price__usd__range=(min_price, max_price))

I want to be able to change the usd part based on a selected currency.

Python Solutions


Solution 1 - Python

Yes, It does. Use **kwargs in a function definition.

Example:

def f(**kwargs):
    print kwargs.keys()


f(a=2, b="b")     # -> ['a', 'b']
f(**{'d'+'e': 1}) # -> ['de']

But why do you need that?

Solution 2 - Python

If I understand what you're asking correctly,

qset.filter(**{
    'min_price_' + selected_currency + '_range' :
    (min_price, max_price)})

does what you need.

Solution 3 - Python

You can easily do this by declaring your function like this:

def filter(**kwargs):

your function will now be passed a dictionary called kwargs that contains the keywords and values passed to your function. Note that, syntactically, the word kwargs is meaningless; the ** is what causes the dynamic keyword behavior.

You can also do the reverse. If you are calling a function, and you have a dictionary that corresponds to the arguments, you can do

someFunction(**theDictionary)

There is also the lesser used *foo variant, which causes you to receive an array of arguments. This is similar to normal C vararg arrays.

Solution 4 - Python

Yes, sort of. In your filter method you can declare a wildcard variable that collects all the unknown keyword arguments. Your method might look like this:

def filter(self, **kwargs):
    for key,value in kwargs:
        if key.startswith('min_price__') and key.endswith('__range'):
            currency = key.replace('min_price__', '').replace('__range','')
            rate = self.current_conversion_rates[currency]
            self.setCurrencyRange(value[0]*rate, value[1]*rate)

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
Questionuser42876View Question on Stackoverflow
Solution 1 - PythonjfsView Answer on Stackoverflow
Solution 2 - PythonJames HopkinView Answer on Stackoverflow
Solution 3 - PythonBenjamin PollackView Answer on Stackoverflow
Solution 4 - PythonMarkView Answer on Stackoverflow