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. python - django 里自定義的 login 方法,如何使用 login_required()2. android-studio - Android 動(dòng)態(tài)壁紙LayoutParams問(wèn)題3. sql語(yǔ)句如何按or排序取出記錄4. angular.js - 不適用其他構(gòu)建工具,怎么搭建angular1項(xiàng)目5. 主從備份 - 跪求mysql 高可用主從方案6. python如何不改動(dòng)文件的情況下修改文件的 修改日期7. mysql優(yōu)化 - mysql count(id)查詢速度如何優(yōu)化?8. css3 - [CSS] 動(dòng)畫(huà)效果 3D翻轉(zhuǎn)bug9. mysql主從 - 請(qǐng)教下mysql 主動(dòng)-被動(dòng)模式的雙主配置 和 主從配置在應(yīng)用上有什么區(qū)別?10. node.js - node_moduls太多了
