python的jinja中中文問題
問題描述
# -*- 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)問怎么處理呢
問題解答
回答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. 老師 我是一個(gè)沒有學(xué)過php語言的準(zhǔn)畢業(yè)生 我希望您能幫我一下2. mysql如何配置遠(yuǎn)程php外網(wǎng)鏈接數(shù)據(jù)庫3. mysql - eclispe無法打開數(shù)據(jù)庫連接4. mysql 5萬張表 導(dǎo)出成sql 不要內(nèi)容,只要結(jié)構(gòu),非常慢。如何解決啊?5. 數(shù)據(jù)庫 - mysql中有沒查看數(shù)據(jù)大小的函數(shù)??6. 導(dǎo)入數(shù)據(jù)庫不成功7. PHP單例模式8. mysql - 關(guān)于數(shù)據(jù)緩存策略方面的疑惑9. mysql如何判斷數(shù)據(jù)不存在則插入呢?10. mysql無法刪除字段(錯(cuò)誤1091),但是對(duì)該字段設(shè)置主鍵后就可刪除,為什么?
