使用Python的Flask框架和Bootstrap框架结合开发web项目非常方便,但今天在写项目时遇到一个问题,上网查了很久都没有找到具体的方法,最后尝试进行修改Python文件解决问题。
问题过程:
在Python文件中使用flask定义的表单进行表单类文件的编写,demon代码如下:
# _*_ coding:utf-8 _*_
from flask import Flask,render_template
from flask.ext.wtf import Form
#from flask_wtf import Form
from flask.ext.bootstrap import Bootstrap
#from flask_bootstrap import Bootstrap
from wtforms import StringField,SubmitField
from wtforms.validators import Required
class NameForm(Form):
name = StringField('您的名字:',validators=[Required()]) #注意这里的中文
submit = SubmitField('提交')
app = Flask(__name__)
app.config['SECRET_KEY'] = 'the key'
bootstrap = Bootstrap(app)
@app.route('/',methods=['GET','POST'])
def index():
name = None
nameForm = NameForm()
if nameForm.validate_on_submit():
name = nameForm.name.data
nameForm.name.data = ''
return render_template('index.html',form=nameForm,name=name)
if __name__ == '__main__':
app.run(debug=True)
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
{% block title %}首页{% endblock %}
</head>
<body>
{% if name %}
<h1>Hello,{{ name }}!</h1>
{% else %}
<h1>Hello,Stranger!</h1>
{% endif %}
<form method="post">
{{ form.hidden_tag() }} <!-- 隐藏表单字段,是为了防止CSRF,所有开启防止CSRF的功能后表单都要加上这句话 -->
{{ form.name.label }} <!-- 这是取定义的表单类中的name字段的第一个参数的标签,相当于input前面的文字 -->
{{ form.name() }} <!-- 显示定义的表单的name字段的内容,相当于一个<input type='text'> -->
{{ form.submit() }} <!-- 显示定义的表单类中的submit字段内容,相当于一个<input type='submit'> -->
</form>
</body>
</html>
在上面的Python文件中我们可以看到,使用了中文“您的名字:”。在之前的开发中,因为之前知道Python的默认编码是Unicode的,所以要在Python文件的头部加入 # _*_ coding:utf-8 _*_ 。但这里是在html代码中使用flask的 form.name.label 输出Python文件中的中文,虽然我的html文件也设置了使用utf-8进行编码,但不知道为什么还是出现错误:
UnicodeDecodeError: 'ascii' codec can't decode byte 0xe6 in position 0: ordinal not in range(128)
为了解决这个问题,可以使用以下方法:
在Python的安装目录的lib目录下找到 mimetypes.py ,我的路径为: Python\Python27\Lib ,打开进行编辑,将如下代码加入到import之后,
default_encoding = 'utf-8'
if sys.getdefaultencoding() != default_encoding:
reload(sys)
sys.setdefaultencoding(default_encoding)
我加入的位置:
之后重启Python,运行相关文件,那么这次成功,可以正常显示中文:
本人经验,仅供参考!