python的jinja中中文問(wèn)題
問(wèn)題描述
# -*- coding: utf-8 -*-import shelvefrom datetime import datetimefrom flask import Flask, render_template, redirect, request, escape, Markupapp = Flask(__name__)DATA_FILE = ’message’def save_data(name, comment, create_at): '''保存提交的數(shù)據(jù)''' database = shelve.open(DATA_FILE) if ’message_list’ not in database:message_list = [] else:message_list = database[’message_list’] message_list.insert(0, {’name’: name,’comment’: comment,’create_at’: create_at, }) database[’message_list’] = message_list database.close()def load_data(): '''返回已提交的數(shù)據(jù)''' database = shelve.open(DATA_FILE) message_list = database.get(’message_list’, []) database.close() return message_listdef post(): '''用于提交評(píng)論的URL''' name = request.form.get(’name’) comment = request.form.get(’comment’) create_at = datetime.now() save_data(name, comment, create_at) return redirect(’/’)@app.route(’/’)def index(): message_list = load_data() return render_template(’index.html’, message_list=message_list)@app.template_filter(’nl2br’)def nl2br_filter(s): return escape(s).replace('n', Markup(’<br>’))@app.template_filter(’datetime_fmt’)def datetime_fmt_filter(dt): return dt.strftime(’%Y-%m-%d %H:%M:%S’)if __name__ == ’__main__’: app.run(’127.0.0.1’, 8001, debug=True)
{% for message in message_list %}<h3>{{ message.name }} 的消息 ({{ message.create_at | datetime_fmt }}):</h3><p> {{ message.comment | nl2br }}<p></p>{% endfor %}
運(yùn)行程序錯(cuò)誤提示:
UnicodeDecodeError
UnicodeDecodeError: ’ascii’ codec can’t decode byte 0xef in position 16: ordinal not in range(128)
就是有中文的這一行出錯(cuò)了,請(qǐng)問(wèn)怎么處理呢
問(wèn)題解答
回答1:報(bào)錯(cuò)應(yīng)該是你python程序那邊報(bào)吧, 試下把你python那邊的中文編碼處理下, 或者試下全部用unicode吧, 參考下面:
with open(’test_%s.html’ % date, ’w’) as f:f.write(a.render( {’date’: date,’total’: 30,’title’: u’報(bào)告’ % date, u’project_list’: project_info }).encode(’utf8’))
相關(guān)文章:
1. mac OSX10.12.4 (16E195)下Mysql 5.7.18找不到配置文件my.cnf2. mysql - 怎么生成這個(gè)sql表?3. mysql儲(chǔ)存json錯(cuò)誤4. php - 公眾號(hào)文章底部的小程序二維碼如何統(tǒng)計(jì)?5. mysql - 表名稱(chēng)前綴到底有啥用?6. mysql - 數(shù)據(jù)庫(kù)表中,兩個(gè)表互為外鍵參考如何解決7. Navicat for mysql 中以json格式儲(chǔ)存的數(shù)據(jù)存在大量反斜杠,如何去除?8. 在mybatis使用mysql的ON DUPLICATE KEY UPDATE語(yǔ)法實(shí)現(xiàn)存在即更新應(yīng)該使用哪個(gè)標(biāo)簽?9. mysql - 數(shù)據(jù)庫(kù)建字段,默認(rèn)值空和empty string有什么區(qū)別 11010. sql語(yǔ)句 - 如何在mysql中批量添加用戶(hù)?
