用于urldecode的django自定义过滤器,可以超出最大递归深度

时间:2012-10-18 17:03:28

标签: django urldecode

我想写一个urldecode模板过滤器,我的app下面有一个模板标签文件夹,代码如下:

from django import template
from urllib import unquote

register = template.Library()

@register.filter
def unquote(value):
    return unquote(value)

class SetVarNode(template.Node):

    def __init__(self, var_name, var_value):
        self.var_name = var_name
        self.var_value = var_value

    def render(self, context):
        try:
            value = template.Variable(self.var_value).resolve(context)
        except template.VariableDoesNotExist:
            value = ""
        context[self.var_name] = value
        return u""

@register.tag(name='set')
def set_var(parser, token):
    """
        {% set <var_name>  = <var_value> %}
    """
    parts = token.split_contents()
    if len(parts) < 4:
        raise template.TemplateSyntaxError("'set' tag must be of the form:  {% set <var_name>  = <var_value> %}")
    return SetVarNode(parts[1], parts[3])

然后我在我的模板中调用我的注册过滤器,如下所示:

  

kmz.file |引文结束

任何想法为什么?

1 个答案:

答案 0 :(得分:1)

这是因为你导入了unquote然后重新定义它。

请改用:

from urllib import unquote as unquote_old

@register.filter
def unquote(value):
    return unquote_old(value) 

from urllib import unquote

@register.filter
def unquote_new(value):
    return unquote(value)