zoukankan      html  css  js  c++  java
  • python 在windows 中文显示

    今天看到mechanize,在网上找例子实验,发现只要代码里出现中文,就会报错

    SyntaxError: Non-ASCII character 'xe4' in file testMech.py on line 2,
    but no encoding declared; see http://python.org/dev/peps/pep-0263/ for details

    python的默认编码文件是用的ASCII码

    使用notepad++

    (1)文件编码为:以UTF-8无BOM格式编码

    如果python文件中使用了中文等非英语字符,就会报错了

    解决的方法

    在Python源文件的第一行加上

    # coding=UTF-8

    或者

    # -*- coding:UTF-8 -*-

    输出

    # -*- coding:UTF-8 -*-
    string='你好'  
    print string

    改为

    # -*- coding:UTF-8 -*-
    string='你好'  
    print string.decode('UTF-8') 

    中文字符串是保存在元组、列表或者字典里,可以调用json模块的dumps方法

    # -*- coding:UTF-8 -*-
    import json  
    print u'你好' 
    string='你好'  
    print string.decode('UTF-8') 
    t_tuple=('','你好')  
    t_list=['','你好']  
    t_dict={1:'',2:'你好'}  
    print json.dumps(t_tuple,encoding='UTF-8',ensure_ascii=False)  
    print json.dumps(t_list,encoding='UTF-8',ensure_ascii=False)  
    print json.dumps(t_dict,encoding='UTF-8',ensure_ascii=False) 

    (2)文件编码为:以ANSI格式编码

    #coding:gbk
    string='你好'  
    print string

    中文输出正常

    #coding:gbk
    import json
    string='你好'  
    print string
    t_tuple=('','你好')  
    t_list=['','你好']  
    t_dict={1:'',2:'你好'}  
    print json.dumps(t_tuple,encoding='gbk',ensure_ascii=False)  
    print json.dumps(t_list,encoding='gbk',ensure_ascii=False)  
    print json.dumps(t_dict,encoding='gbk',ensure_ascii=False) 

    #coding:gb2312或者#coding:gbk都可以的

  • 相关阅读:
    zookeeper常用命令
    linux查看日志相关命令
    第三十一期: VueRouter源码浅析 传统前端和多媒体前端
    第二十八期:模型,模块,组件,框架和架构
    星际2光速注卵
    星际心得
    英语词根研究和单词记忆
    星际2如何离线模式打电脑和rpg地图练操作
    星际研究
    第一篇帖子:不利用中间变量交换两个数字的小算法题
  • 原文地址:https://www.cnblogs.com/baby123/p/8085662.html
Copyright © 2011-2022 走看看