如何使python2在使用中文的时候,不用加u前缀?

这个需求是这样来的,最近在用django做一个项目,考虑到移动性以及以后给团队的人用,所以我打算把一部分模板变量写成中文,类似的效果是这样的{{ 文章内容 }} 这样以后自己在引用的时候也比较方便.
但是在python2.7,我使用上下渲染是这样的.
context[u'网站标题'] ,前面必须要加u,django才能识别.这样显得特别麻烦,而且变量一多也会漏掉,有没有比较的方法,可以就直接使用中文就可以? 不要劝我换python3,有些模块python3还不支持!


其实总结一下 问题很简单

u'中文' 如何能 这样中文,直接调用?需要什么包或什么库可以省掉这个
不知道我的描述清楚吗?

阅读 4.6k
3 个回答

from __future__ import unicode_literals

django模版系统应该也会有跟jinja2差不多的filter功能吧。
就是这样:

@myapp.app_template_filter(name='chsdesc')
def chs_description(eng_str):
    desc = {
        'title': '标题',
        'body': '正文',
        }
    return desc.get(eng_str, '未知').decode('utf-8')

前台

<p>{{ title|chsdesc }}</p>

为什么要省掉?记住只要是中文就加u就好了。这是py2的老问题,如果你不愿换py3,就只能默默承受了

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题