用jieja做測試學習的時候遇到這么一個報錯
jinja2.exceptions.TemplateSyntaxError jinja2.exceptions.TemplateSyntaxError: unexpected char '…' at 208 Traceback (most recent call last) File "/anaconda3/lib/python3.7/site-packages/flask/app.py", line 2309, in __call__ return self.wsgi_app(environ, start_response) File "/anaconda3/lib/python3.7/site-packages/flask/app.py", line 2295, in wsgi_app response = self.handle_exception(e) File "/anaconda3/lib/python3.7/site-packages/flask/app.py", line 1741, in handle_exception reraise(exc_type, exc_value, tb) File "/anaconda3/lib/python3.7/site-packages/flask/_compat.py", line 35, in reraise raise value File "/anaconda3/lib/python3.7/site-packages/flask/app.py", line 2292, in wsgi_app response = self.full_dispatch_request() File "/anaconda3/lib/python3.7/site-packages/flask/app.py", line 1815, in full_dispatch_request rv = self.handle_user_exception(e) File "/anaconda3/lib/python3.7/site-packages/flask/app.py", line 1718, in handle_user_exception reraise(exc_type, exc_value, tb) File "/anaconda3/lib/python3.7/site-packages/flask/_compat.py", line 35, in reraise raise value File "/anaconda3/lib/python3.7/site-packages/flask/app.py", line 1813, in full_dispatch_request rv = self.dispatch_request() File "/anaconda3/lib/python3.7/site-packages/flask/app.py", line 1799, in dispatch_request return self.view_functions[rule.endpoint](**req.view_args) File "/Users/chenjian/PycharmProjects/testAnaconda/microblog/app/views.py", line 19, in index user = user) File "/anaconda3/lib/python3.7/site-packages/flask/templating.py", line 134, in render_template return _render(ctx.app.jinja_env.get_or_select_template(template_name_or_list), File "/anaconda3/lib/python3.7/site-packages/jinja2/environment.py", line 869, in get_or_select_template return self.get_template(template_name_or_list, parent, globals) File "/anaconda3/lib/python3.7/site-packages/jinja2/environment.py", line 830, in get_template return self._load_template(name, self.make_globals(globals)) File "/anaconda3/lib/python3.7/site-packages/jinja2/environment.py", line 804, in _load_template template = self.loader.load(self, name, globals) File "/anaconda3/lib/python3.7/site-packages/jinja2/loaders.py", line 125, in load code = environment.compile(source, name, filename) File "/anaconda3/lib/python3.7/site-packages/jinja2/environment.py", line 591, in compile self.handle_exception(exc_info, source_hint=source_hint) File "/anaconda3/lib/python3.7/site-packages/jinja2/environment.py", line 780, in handle_exception reraise(exc_type, exc_value, tb) File "/anaconda3/lib/python3.7/site-packages/jinja2/_compat.py", line 37, in reraise raise value.with_traceback(tb) File "/Users/chenjian/PycharmProjects/testAnaconda/microblog/app/templates/index.html", line 12, in template <!--Jinja2 模板同樣支持控制語句,像在 {%…%} 塊中。讓我們在我們的模板中添加一個 File "/anaconda3/lib/python3.7/site-packages/jinja2/environment.py", line 497, in _parse return Parser(self, source, name, encode_filename(filename)).parse() File "/anaconda3/lib/python3.7/site-packages/jinja2/parser.py", line 901, in parse result = nodes.Template(self.subparse(), lineno=1) File "/anaconda3/lib/python3.7/site-packages/jinja2/parser.py", line 879, in subparse next(self.stream) File "/anaconda3/lib/python3.7/site-packages/jinja2/lexer.py", line 359, in __next__ self.current = next(self._iter) File "/anaconda3/lib/python3.7/site-packages/jinja2/lexer.py", line 562, in wrap for lineno, token, value in stream: File "/anaconda3/lib/python3.7/site-packages/jinja2/lexer.py", line 739, in tokeniter name, filename) jinja2.exceptions.TemplateSyntaxError: unexpected char '…' at 208 The debugger caught an exception in your WSGI application. You can now look at the traceback which led to the error. To switch between the interactive traceback and the plaintext one, you can click on the "Traceback" headline. From the text traceback you can also create a paste of it. For code execution mouse-over the frame you want to debug and click on the console icon on the right side. You can execute arbitrary Python code in the stack frames and there are some extra helpers available for introspection: dump() shows all variables in the frame dump(obj) dumps all that's known about the object
遇到報錯不能慌,仔細分析報錯內容:
第一處就是這里:
jinja2.exceptions.TemplateSyntaxError: unexpected char '…' at 208
從上面的報錯隱約感覺似乎和字符相關,但是不能確定具體是哪里的,然后往下看,另外一處報了(主要其他處也看不太明白):
File "/Users/chenjian/PycharmProjects/testAnaconda/microblog/app/templates/index.html", line 12, in template <!--Jinja2 模板同樣支持控制語句,像在 {%…%} 塊中。讓我們在我們的模板中添加一個
自取檢查index.html 這個文件中發現有中文的注釋,似乎是這里影響了,但是我不熟悉jieba,所以刪掉了這個中文注釋,測試了一下,報錯就消失了。
問題解決了,但是不明白為啥這里的jiaba 不能解析注釋掉的 html的中文代碼。