Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How passing string on filter keyword to Django Objects Model?

How can i pass variables on a keyword object filter on a view?

I have:

my_object = MyModel.objects.filter(my_keyword =my_filter_values)

I want to grab my_keyword from a variable coming from a string, like this:

my_string = 'my_keyword'
my_object = MyModel.objects.filter(my_string=my_filter_values)

But this doesn't work because Django doesn't know my_string from MyModel.

Edit: I've found this SO question - I'll test and report back.

like image 929
laurent Avatar asked Aug 27 '11 06:08

laurent


1 Answers

You can do something like this:

my_filter = {}
my_filter[my_keyword] = my_filter_value

my_object = MyModel.objects.filter(**my_filter)

As an example, your variables might be:

my_keyword = 'price__gte'
my_filter_value = 10

Which would result in getting all objects with a price >= 10. And if you want to query on more than one field, you can just add another line below my_filter[my_keyword]:

my_filter[my_keyword] = my_filter_value
my_filter[my_other_keyword] = my_other_filter_value
like image 163
Sam Starling Avatar answered Oct 15 '22 23:10

Sam Starling