perl输出中文乱码
运行的时候输出的内容变成了中文乱码,原因首先来查找一下自己的perl的模块里面是否有Encode-CN。请运行打开你的cmd并输入perldoc -l Encode::CN
如果出现了地址
则就是有,如果没有需要进行该模块的安装。
安装方式有很多种,我这里用的是CPAN的安装方式,且前提是我已经有perl的情况(但是没有CPAN),先下载CPAN。
只需要下载如下的两个包:
dmake:
http://mirrors.163.com/cpan/authors/id/S/SH/SHAY/
dmake-4.12.2.2.zip
cpanm(App::cpanminus):
http://mirrors.163.com/cpan/authors/id/M/MI/MIYAGAWA/
App-cpanminus-1.7040.tar.gz
可以选择不同的版本,时间推移版本有更新,除掉红色部分即可
-
将dmake-4.12.2.2.zip解压,把
startup 文件夹
和dmake.exe
文件放入D:\Perl\bin
-
解压App-cpanminus-1.7040.tar.gz 到任意目录,cmd窗口进入,输入如下命令:
perl Makefile.PLdmake testdmake install
之后可以运行了。(选择镜像节点可以加快下载速度且稳定)
cpanm --mirror http://mirrors.163.com/cpan Encode-CN
安装模块后,再次运行程序查看是否有乱码。如果乱码情况还存在,可能的原因就是操作系统的编码问题。
进行cmd输入chcp
获得编码类型代码。活动代码页是936,936代码页对应的是gb2312(即中文),或者说是gbk。和模块中使用的不一样。只需要在代码中加入如下:
在代码头部输入:use utf8;#引入utf8模块 脚本内的字符串使用utf8作为编码格式binmode(STDOUT,":encoding(gbk)");#标准输出使用gbk作为编码格式,也可以把gbk改为gb2312binmode(STDIN,":encoding(gbk)");#如果涉及到输入流,例如读文件,不加这条读中文文件会出现乱码binmode(STDERR,":encoding(gbk)");#如果异常错误中的字符串有中文,请加上STDERR,否则也会出现乱码
一定要注意一点,如果代码涉及到读取中文的文件,一定要加上binmode(STDIN,":encoding(gbk)");
还有一种方法,针对我们STDIN、STDOUT、STDERR(即标准输入、标准输出和标准错误)统统使用某种编码作为编码格式。
代码如下:
use utf8;use open ":encoding(gbk)",":std";#标准输入、输出、错误皆用gbk编码格式进行编码