在Windows的CMD中如何设置支持UTF8编码?

   这个问题很多人开始都会不知道,当然包括曾经的我,当用到的时候,只好求助于伟大的股沟和度娘了。网上有设置的方法,但说明确不够详细系统,说设置字体 为:Lucida Console。问题是,在默认方式下,只有点阵字体,哪有什么Lucida Console。所以,在自己成功设置后,拿出来和大家分享下过程,下面就让我们找出Lucida Console来设置吧。

  这里需要先了解些内容:

CHCP

CHCP是MS DOS中的命令,用来显示或设置活动代码页编号的。用法是:

CHCP [nnn]

其中nnn指定的是代码页的编号。这个参数是可选的,在命令行下如果不指定这个代码页编号,那么默认是显示当前的代码页编号。比如,在默认的cmd窗口中,我们输入chcp,显示的将类似:

活动的代码页: 936

这里的936表示当前使用的是简体中文(GB2312)编码。

UTF8

你也需要了解编码的一些知识,为了完成支持UTF8的工作,你至少需要知道UTF8代码页的编号:65001。更多关于编码的内容,这里不赘述,请自行查找相关内容。

有这两个知识点,接下来,让cmd支持UTF8就变得容易了。

1. 运行CMD;

2. 输入 CHCP,回车查看当前的编码;

3. 输入CHCP 65001,回车;

4. 仅如此,还是不能支持UTF8的正常显示,你还要在窗体上右键,选择属性,来设置字体;

5. 操作完上面几步后,即使你原来的字体里面没有显示Lucida Console这个字体,现在应该也能看到了。选择它。如果原来就有,可以选上它先试试,不行在执行上述步骤(这里补充:至少我本机需要CHCP 65001下,有朋友说不要);

6. 选择只应用到本窗体,确认。

这时候,你的Console里面,应该支持UTF8了。

有些朋友也想知道如何在CMD显示更多的字体,这个其实也是有办法的,只要在注册表(路径:HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Console\TrueTypeFont)中添加就好了。需要注意的是,添加的字体需要是定宽的(fixed-width)。操作示意图:

上图来自这里(英文)。需要的可以直接访问。

更改cmd代码页,修正中文显示

爱国者

  • 发布时间: 2013/02/13 13:37
  • 阅读: 10604
  • 收藏: 1
  • 点赞: 1
  • 评论: 0

执行以下相应的命令:

rem 英文
chcp 437

rem 日文
chcp 932

rem 简体中文
chcp 936

rem 韩文
chcp 949

rem 繁体中文
chcp 950

rem utf-8
chcp 65001

如果cmd的默认代码页属性修改不了,那么修改注册表:

1 win键+R打开“运行”对话框,输入regedit打开注册表编辑器。

2 找到 [HKEY_CURRENT_USER\Console\%SystemRoot%_system32_cmd.exe]

3 修改"CodePage"=dword:000003a8

【注】十六进制"000003a8"或十进制"936",表示“936 (ANSI/OEM - 简体中文 GBK)”。

如果代码页改成65001之后,仍无法正常显示UTF-8字符,则需要改变字体属性:在命令行标题栏上点击右键,选择"属性"->"字体",将字体修改为True Type字体"Lucida Console",然后点击确定将属性应用到当前窗口。
    通过以上操作并不能完全解决问题,因为显示出来的内容有可能不完全。可以先最小化,然后最大化命令行窗口,文件的内容就完整的显示出来了。

----------------------------------------------------------------------------------------------------------------

附: chcp详解

功能说明 
显示活动控制台代码页数量,或更改该控制台的活动控制台代码页。如果在没有参数的情况下使用,则 chcp 显示活动控制台代码页的数量。

补充说明 

有随 XOX 一起安装的原始设备制造商 (OEM) 代码页才能在使用 Raster
字体的命令提示符窗口中正常显示。其他代码页则可在全屏幕模式下或者在使用 TrueType 字体的命令提示符窗口中正确显示。 就像在 MS-DOS
中一样,您不必准备代码页。 在指派了新代码页之后启动的程序将使用该新代码页,但如果程序(除了
Cmd.exe)是在指派新代码页之前启动的,那么该程序将使用原来的代码页。

语法 
chcp [NNN]

参数 
NNN 指定代码页。下表列出了MSDOS所有支持的代码页及其国家(地区)或者语言:
代码页     国家(地区)或语言
437          美国
850          多语言(拉丁文 I)
852          斯拉夫语(拉丁文 II)
855          西里尔文(俄语)
857          土耳其语
860          葡萄牙语
861          冰岛语
863          加拿大 - 法语
865          日耳曼语
866          俄语
869           现代希腊语 
936           简体中文
950           繁体中文
65001       UTF-8

/? 在命令提示符下显示帮助。

示例 
要查看活动代码页设置,请键入:

chcp

出现类似于下面内容的消息:
活动代码页:437

如果要将活动代码页更改为 850(多语言),请键入:

chcp 850

如果指定的代码页无效,则会显示以下错误消息:

无效代码页

时间: 2024-10-12 01:02:53

在Windows的CMD中如何设置支持UTF8编码?的相关文章

php开启mbstring扩展并设置支持utf-8编码

前一段时间使用一个服务的接口,因为调用接口时使用的参数里面有中文,调用接口会出现异常问题,后来才明白是编码不一致的问题.然而,我本地项目开发使用的是utf-8,接口那边也是需要utf-8的,那么问题来了,到底哪里的编码不一致呢? 请教了一下高手,原来是php的扩展mbstring没有开启,下面就是开启mbstring扩展,并配置支持utf-8编码的方法: 首先,去掉;extension=php_mbstring.dll 前面的";"号,开启mbstring扩展: 然后,将对应项都改成下

Python的raw_input语句包含中文,在Windows环境CMD中显示乱码的解决方法

Python的raw_input语句中如果包含中文,在Windows环境CMD中执行时会显示乱码: 由于raw_input语句不支持unicode显示,在中文字符串前加u会报错: 解决办法: 在语句中进行强制的编码转换,格式如下: shuzi = raw_input (unicode('请输入日期:','utf-8').encode('gbk'))

Python 中如何设置 stdout 的编码?

Python开发中,有时候进程的运行环境里,locale 会被设置成只支持 ASCII 字符集的(比如).这时候 Python 就会把标准输出和标准错误的编码给设置成 ascii,造成输出中文时报错. 一种解决办法是设置支持 UTF-8 的 locale,但是那需要在 Python 进程启动前设置.启动之后,初始化过了,再设置 locale也不会重新初始化那些对象. 另一种办法是往 sys.stdout.buffer 这种地方直接写 bytes.理论上完全没问题,但是写起程序来好累-- 我就去找

python基础-PyCharm设置作者信息模板_修改解释器_设置软件UTF-8编码

一.PyCharm 设置作者信息模板 1.File---Settings---在搜索框中搜索:File and Code Templates---Python scripts 1 #!/usr/bin/env python 2 # -*- coding:utf-8 -*- 3 #Author: huzhihua 二.修改解释器方法 File---settings---project:python---project interpreter 三.设置软件UTF-8 编码File---Setting

解决:IE中不能自动选择UTF-8编码的解决方法

IE中不能自动选择UTF-8编码的解决办法 在windows操作系统上使用IE作为浏览器时.常常会发生这样的问题:在浏览使用UTF-8编码的网页时,浏览器无法自动侦测(即没有设定“自动选择”编码格式时)该页面所用的编码.即使网页已经声明过编码格式: <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /> ,由此造成某些含有中文UTF-8编码的页面产生空白输出. 问题分析:

Windows的cmd中cd指令切换路径

1,按下WIN+R键 输入cmd,打开cmd窗口.2,默认路径为用户文档路径,如果想切换到D盘 ,输入cd d:是不行的.3,AppData是C盘里的一个目录,如果用cd指令想切换到这个目录之下是可以的.4,如果我们要切换盘符的目录,正确的用法是在cd 和路径中间 增加一个'/d'    cd /d d:5,当我们要切换盘符时,可以不用cd指令  直接用 盘符: 例如e:    6,那CD命令倒底有什么用呢?cmd中输入 cd /? ,你可以得到其对应的帮助文件.其主要功能是是显示当前目录的名称

windows自带记事本导致文本文件(UTF-8编码)开头三个字符乱码问题

在windows平台下,使用系统的记事本以UTF-8编码格式存储了一个文本文件,但是由于Microsoft开发记事本的团队使用了一个非常怪异的行为来保存UTF-8编码的文件,它们自作聪明地在每个文件开头添加了0xefbbbf(十六进制)的字符,所以我们就会遇到很多不可思议的问题,比如,网页第一行可能会显示一个"?",明明正确的程序一编译就报出语法错误,等等. 下面为一段测试程序,由记事本编辑的文本文件导致文件开头前三个字符乱码. #include <stdio.h> #de

Windows的cmd中cd指令

1,如果需要切换的路径是在C盘,那么用cd C:\... 2,如果需要切换的路径是在非C盘,那么用cd /d D:\... 2.1未加/d时,进入E盘目录失败 2.2加/d时,进入E盘目录成功 3.dir命令,查看此目录下有哪些文件夹 原文地址:https://www.cnblogs.com/knowledge-poppy/p/9853172.html

apache-tomcat-7中怎么设置URIEncoding=utf-8?

Tomcat\conf\server.xml中找到: <Connector port="8080"  protocol="HTTP/1.1"  connectionTimeout="20000"  redirectPort="8443"/> 改成: <Connector port="8080"  protocol="HTTP/1.1"  connectionTimeou