Perl输出中文乱码解决方法

Perl是一种动态解释型的脚本语言。 最初的设计者为拉里·沃尔(Larry Wall),它于1987年12月18日发表。Perl借取了C、sed、awk、shell scripting 以及很多其他编程語言的特性。其中最重要的特性是他内部集成了正则表达式的功能,以及巨大的第三方代码库 CPAN。

方法/步骤

就以 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 "你好";

当前名称:Perl输出中文乱码解决方法
文章位置:http://www.shufengxianlan.com/qtweb/news47/392347.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联