Jest to możliwe i dość proste.
Django dopuszcza tylko jeden argument do twojego filtra, ale nie ma powodu, dla którego nie możesz umieścić wszystkich argumentów w jednym łańcuchu, używając przecinka do ich oddzielenia.
Na przykład, jeśli chcesz filtr, który sprawdza, czy zmienna X znajduje się na liście [1,2,3,4], będziesz potrzebować filtru szablonu, który wygląda następująco:
{% if X|is_in:"1,2,3,4" %}
Teraz możemy stworzyć Twój szablon w następujący sposób:
from django.template import Library
register = Library()
def is_in(var, args):
if args is None:
return False
arg_list = [arg.strip() for arg in args.split(',')]
return var in arg_list
register.filter(is_in)
Linia, która tworzy arg_list, jest wyrażeniem generatora, które dzieli łańcuch args na wszystkie przecinki i wywołuje .strip () w celu usunięcia wszelkich spacji wiodących i końcowych.
Jeśli na przykład trzeci argument jest liczbą int, po prostu wykonaj:
arg_list[2] = int(arg_list[2])
Lub jeśli wszystkie z nich to int:
arg_list = [int(arg) for arg in args.split(',')]
EDYCJA: teraz, aby konkretnie odpowiedzieć na twoje pytanie, używając par klucz, wartość jako parametrów, możesz użyć tej samej klasy, której Django używa do parsowania ciągów zapytań z adresu URL, co z kolei ma również tę zaletę, że obsługuje kodowanie znaków zgodnie z twoimi ustawieniami. .
Tak więc, podobnie jak w przypadku ciągów zapytań, każdy parametr jest oddzielony znakiem „&”:
{{ attr.name|replace:"cherche=_&remplacement= " }}
Twoja funkcja zamiany będzie teraz wyglądać następująco:
from django import template
from django.http import QueryDict
register = template.Library()
@register.filter
def replace(value, args):
qs = QueryDict(args)
if qs.has_key('cherche') and qs.has_key('remplacement'):
return value.replace(qs['cherche'], qs['remplacement'])
else:
return value
Możesz to nieco przyspieszyć, ryzykując wykonanie nieprawidłowych wymian:
qs = QueryDict(args)
return value.replace(qs.get('cherche',''), qs.get('remplacement',''))