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都可以的

  • 相关阅读:
    总结的反爬虫手段(持续更新)
    爬虫类编程笔记导航
    技术开发流程小公司
    敏捷开发学习笔记(一)
    .NET Framework各版本比较
    linux shell 之 cut
    Hive insert overwrite 出现错误解决方法
    hive join
    linux shell 之 grep
    hive实现not in
  • 原文地址:https://www.cnblogs.com/baby123/p/8085662.html
Copyright © 2011-2022 走看看