相信很多小伙伴在使用 Perl 语言的时候,经常会遇到这样一个问题,Perl 不支持中文?perl 输入或者输出中文会出现乱码。这时怎么办呢?下面小编就教小伙伴们如何解决这个问题。
方法/步骤
就以 windows 上的 ActivePerl 为例。
小编的代码特别简单,就是一句:
print "你好";
却出现了乱码,如图。
遇到这样的问题,我们要怎么办?
其实就是 perl 编码的问题,这其实和我们操作系统的编码有关。
我们打开 cmd 命令提示符,输入 chcp 获得编码类型代码。
可见,小编这里的 windows 是代号 936 为默认编码格式。
然后我们可以看到,936 代码页对应的是 gb2313(即中文),或者说是 gbk。
我们知道了我们 windows 是用 gb2312 编码的,这时我们只要改变编码格式即可。
在代码头部输入:
use utf8; #引入utf8模块 脚本内的字符串使用utf8作为编码格式 binmode(STDOUT,":encoding(gbk)"); #标准输出使用gbk作为编码格式,也可以把gbk改为gb2312 binmode(STDIN,":encoding(gbk)"); #如果涉及到输入流,例如读文件,不加这条读中文文件会出现乱码 binmode(STDERR,":encoding(gbk)"); #如果异常错误中的字符串有中文,请加上STDERR,否则也会出现乱码 print "你好";
此时是不是就能正常输出中文了呢?
一定要注意一点,如果代码涉及到读取中文的文件,一定要加 上binmode(STDIN,":encoding(gbk)");。
还有一种方法,针对我们 STDIN、STDOUT、STDERR(即标准输入、标准输出和标准错误)统统使用某种编码作为编码格式。
还是那个简单的小程序,print 输出一个中文。
代码如下:
use utf8; use open ":encoding(gbk)",":std"; #标准输入、输出、错误皆用gbk编码格式进行编码 print "你好";
原文地址:https://jingyan.baidu.com/article/4f7d5712fd36301a21192744.html