开发者问题收集

Python:未知的 Jinja 错误导致脚本无法运行

2019-11-14
276

我正在尝试运行以下 python 命令: $ python stack.py <file_name> 我位于包含 stack.py 文件的正确文件夹中。

但是,我收到以下错误,我不确定如何解决它或为什么现在会发生这种情况。

我尝试升级 jinja $ pip install Jinja2 但没有成功。

我还查看了 stack_error_vals.json 和 stack_error_template.j2,但其中没有任何有用的信息。

关于如何解决这个问题以便我的 python 命令再次成功,有什么想法吗?

  File "stack.py", line 514, in proc_jinja_templates
    output = env.render(vals)
  File "C:\Users\jthomas\AppData\Local\Programs\Python\Python37-32\lib\site-packages\jinja2\asyncsupport.py", line 76, in render
    return original_render(self, *args, **kwargs)
  File "C:\Users\jthomas\AppData\Local\Programs\Python\Python37-32\lib\site-packages\jinja2\environment.py", line 1008, in render
    return self.environment.handle_exception(exc_info, True)
  File "C:\Users\jthomas\AppData\Local\Programs\Python\Python37-32\lib\site-packages\jinja2\environment.py", line 780, in handle_exception
    reraise(exc_type, exc_value, tb)
  File "C:\Users\jthomas\AppData\Local\Programs\Python\Python37-32\lib\site-packages\jinja2\_compat.py", line 37, in reraise
    raise value.with_traceback(tb)
  File "<template>", line 16, in top-level template code
  File "C:/carbon\modules\templates\bridge\configs\config.xml.j2", line 27, in top-level template code
    {%- if v.required or ((v.configdatatype == 'Bool' and v.value in (true,false)) or (v.configdatatype == 'String' and v.value and 'changeme' not in v.value.lower())) -%}
jinja2.exceptions.UndefinedError: 'int object' has no attribute 'lower'

Writing stack_error_vals.json and stack_error_template.j2 for review
2个回答

看起来您的模板假设 v.value 是一个字符串,但在这种情况下,它得到的是一个看起来像整数的东西。

Daniel Finch
2019-11-14
jinja2.exceptions.UndefinedError: 'int object' has no attribute 'lower'

这意味着您尝试应用 .lower() 的对象是一个整数,而不是字符串。

如果没有看到完整代码,您可以尝试

str(v.value).lower()
CDJB
2019-11-14