转 https://blog.csdn.net/Bin_bin_bingo/article/details/80531582

一、乱码现象

利用sublime自带编译快捷方式ctrl+B会出现中文乱码的情况

  1.  
    print("没有循环数据!")
  2.  
    print("完成循环!")

二、寻找原因

1、由于之前我已经安装了插件ConvertToUTF8,排除文本编码错误问题

2、相同的代码在插件sublimerepl搭建的解释器交互下(按F5键),能成功显示中文

。。。。。。在查找了很多案例之后发现

Anaconda插件安装之后会自动生成一个叫“Anaconda Python Builder”的编译系统,在 工具-编译系统-中可以看到

然后在这篇博客里面找到原因,原来是因为sublime读取解释器返回文本的编码不一样,于是通过下面这段代码验证:

  1.  
    import sys
  2.  
    print(sys.stdout.encoding)

用ctrl+B进行编译,返回的是“cp936”,用repl解释器交互返回的是utf-8,说明是由于编码不一致导致的

之后新建了一个编译系统:

在Python3.sublime.build中写入下面代码

  1.  
    {
  2.  
    "cmd":["C:\\Users\\jh\\Anaconda3\\python.exe", "-u", "$file"],
  3.  
    "path":"C:\\Users\\jh\\Anaconda3\\python.exe", // 注意:路径根据自己的python安装路径而定
  4.  
    "file_regex": "^[ ]*File \"(...*?)\", line ([0-9]*)",
  5.  
    "selector": "source.python",
  6.  
    "encoding": "utf-8" ,
  7.  
    "env": {"PYTHONIOENCODING": "utf8"}//通过这句,使编码一致,都是utf8
  8.  
    }

之后再用ctrl+B进行编译,返回“utf-8”,并且能成功打印中文

但是在此之前,因为尝试多种方法,导致anaconda插件的自动补全代码无法使用,于是重装

三、Anaconda插件的正确使用

1、阅读官方指南,官方给的建议是最好每个项目都独立设置

2、根据官方的建议,新建一个project,并编辑项目,在sublime-project文件中写入:

  1.  
    {
  2.  
    "build_systems":
  3.  
    [
  4.  
    {
  5.  
    "name": "Anaconda Python Builder",
  6.  
    "selector": "source.python",
  7.  
    "encoding": "utf-8" ,
  8.  
    "env": {"PYTHONIOENCODING": "utf8"},\\使编码一致
  9.  
    "shell_cmd": "C:\\Users\\jh\\Anaconda3\\python.exe -u \"$file\"",\\解释器路径
  10.  
    }
  11.  
    ],
  12.  
    "folders":
  13.  
    [
  14.  
    {
  15.  
    "follow_symlinks": true,
  16.  
    "path": "."
  17.  
    }
  18.  
    ],
  19.  
    "settings":
  20.  
    {
  21.  
    "python_interpreter": "C:\\Users\\jh\\Anaconda3\\python.exe" \\解释器路径
  22.  
     
  23.  
    }
  24.  
    }

保存。

2、在Preferences > Package Settings > Anaconda,在那里会发现两个不同的条目,Settings-DefaultSettings-User分别选择1和2。这些文件中的任何选项都必须放置在全局范围内。在Settings-User中写入:

  1.  
    { //http://damnwidget.github.io/anaconda/IDE/
  2.  
    //"python_interpreter":"C:\\Users\\jh\\Anaconda3\\envs\\tensorflow\\python.exe",
  3.  
    "python_interpreter":"C:\\Users\\jh\\Anaconda3\\python.exe",
  4.  
    "auto_python_builder_enabled": false,
  5.  
    "suppress_word_completions":true,//禁用掉Sublime Text原生的自动补全
  6.  
    "suppress_explicit_completions":true,
  7.  
    "complete_parameters":true,
  8.  
     
  9.  
    "anaconda_linter_phantoms": true,//提示错误,识别代码中的语法错误,代码建议,格式建议等
  10.  
    "pyflakes_explicit_ignore"://告诉PyFlakes要忽视哪些警告
  11.  
    [
  12.  
    // "Redefined",
  13.  
    "UnusedImport"
  14.  
    // "UndefinedName",
  15.  
    // "UndefinedLocal",
  16.  
    // "UnusedVariable,",
  17.  
    // "UndefinedExport",
  18.  
    // "DuplicateArgument",
  19.  
    // "RedefinedWhileUnused"
  20.  
    ],
  21.  
    "anaconda_linting_behaviour": "always",//模式
  22.  
    "anaconda_linting": true,
  23.  
    "anaconda_linter_delay": 2.0,//周期
  24.  
    "swallow_startup_errors": true,
  25.  
    "env": {"PYTHONIOENCODING": "utf8"} ,
  26.  
    }

sublime text3 中 python3编译出现中文乱码解决方法的更多相关文章

  1. Linux中文件/文本的中文乱码解决方法

    Linux显示在Windows编辑过的中文就会显示乱码是由于两个操作系统使用的编码不同所致.Linux下使用的编码是utf8,而Windows使用的是gb18030.因此,解决Linux打开txt/c ...

  2. url中向后台传递中文乱码解决方法

    方法一: 1.jsp中代码 var userNo = $('#prisoner_id').val();      userNo = encodeURI(userNo);      allPrisone ...

  3. python cmd 窗口 中文乱码 解决方法 (附:打印不同颜色)

    python cmd 窗口 中文乱码 解决方法 (附:打印不同颜色) 前言 在 python 开发中,有时候想通过cmd窗口来和用户交互,比如显示信息之类的,会比自己创建 GUI 来的方便,但是随之而 ...

  4. 记一次Maven发布Jar包中文乱码解决方法

    Maven deploy 乱码 今天使用Maven发布Jar包时,发布功能都是正常的也成功上传到了仓库,就是项目跑越来后出中文中现了乱码: { "code": "SUCC ...

  5. php mysql 中文乱码解决方法

    本文章向码农们介绍php mysql 中文乱码解决方法,对码农们非常实用,需要的码农可以参考一下. 从MySQL 4.1开始引入多语言的支持,但是用PHP插入的中文会出现乱码.无论用什么编码也不行 解 ...

  6. jquery的ajax()函数传值中文乱码解决方法介绍

    jquery的ajax()函数传值中文乱码解决方法介绍,需要的朋友可以参考下 代码如下: $.ajax({ dataType : ‘json', type : ‘POST', url : ‘http: ...

  7. [转]mysql导入导出数据中文乱码解决方法小结

    本文章总结了mysql导入导出数据中文乱码解决方法,出现中文乱码一般情况是导入导入时编码的设置问题,我们只要把编码调整一致即可解决此方法,下面是搜索到的一些方法总结,方便需要的朋友. linux系统中 ...

  8. Zxing中文乱码解决方法

    Zxing中文乱码解决方法总结 尝试过非常多方法  最后发现此方法解决的乱码最多....... 在百度搜索二维码图片 经过前2页的測试  除开一张图之外  其余都能扫描出结果 假设大家有更好的解决方法 ...

  9. unity3d 中文乱码解决方法——cs代码文件格式批量转化UTF8

    在Unity3d中经常会碰到中文乱码的问题,比如代码中的[AddComponentMenu("GameDef/AI/战机AI")],注释,中文文本等等 其原因在于,unity本身是 ...

随机推荐

  1. STM32L476应用开发之二:模拟量数据采集

    采集模拟量数据在一台一起中是必不可少的功能.在本次实验中我们要采集的模拟量值主要包括氧气传感器的输出以及压力变送器的输出. 1硬件设计 我们需要采集数据对精度有一定的要求,而STM32L476自带AD ...

  2. The word 'localhost' is not correctly spelled 这个问题怎么解决

    The word 'localhost' is not correctly spelled 这个问题怎么解决 有时工程中有下划线并提示 The word is not correctly spelle ...

  3. Confluence 6 连接到 Jira 用户管理的建议

    建议 如果下面所有的选项都为是的话: JIRA 应用程序不在高负载下运行. 你仅仅希望在一些不多的应用中跨平台管理你的用户和用户组,例如一个 JIRA 软件服务器和 Confluence 服务器,或者 ...

  4. html table

    <!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...

  5. kindedit编辑器和xxs攻击防护(BeautifulSoup)的简单使用

    一.kindedit编辑器 就是上面这样的编辑输入文本的一个编辑器 这也是一个插件.那么怎么用呢? 1.下载:百度kindedit 2.引入: <script src="/static ...

  6. 拓扑排序基础 hdu1258,hdu2647

    由这两题可知拓扑排序是通过“小于”关系加边建图的 hdu2647 /* 拓扑排序的原则是把“小于”看成有向边 此题反向建图即可 并且开num数组来记录每个点的应该得到的权值 */ #include&l ...

  7. C程序的内存分配及动态内存

    1.程序内存的分配 一个由C/C++编译的程序占用的内存分为以下几个部分:1)栈区(stack) — 由编译器自动分配释放 , 存放为运行函数而分配的局部变量. 函数参数. 返回数据. 返回地址等. ...

  8. Java接口自动化测试之Maven项目的创建(一)

    这里使用Idea创建Maven项目, 过程非常简单, 装好JDK和Idea 1. 安装完后,打开Idea, 选择File→New→Project, 如图 2. 选择maven, 点击Next, 如图 ...

  9. python 给对象绑定属性和方法和__slots__的使用

    # 以c语言为主是静态语言,运行之前先编译,在运行的过程中不允许编辑代码# 在运行的过程中,可以改变,可以添加属性,就是属于动态语言(python) # python动态的添加属性以及方法class ...

  10. python:字符串转换成字节的三种方式及字符转码问题

    str='zifuchuang' 第一种 b'zifuchuang'第二种bytes('zifuchuang',encoding='utf-8')第三种('zifuchuang').encode('u ...