`

perl对中文的处理(encode,decode)(转)

    博客分类:
  • Perl
阅读更多
原文:http://www.cnblogs.com/slaughter/archive/2007/03/15/675791.html
http://lynsead.spaces.live.com/Blog/cns!1pN1cYMeTzpoDjzM1P1IqDFg!135.entry

perl对中文的处理(encode,decode)

最近在处理中文时遇到乱码的问题,google了一下,发现下面这篇文章。茅塞顿开!

Perl从5.6开始已经开始在内部使用utf8编码来表示字符,也就是说对中文以及其他语言字符的处理应该是完全没有问题的。我们只需要利用好Encode这个模块便能充分发挥Perl的utf8字符的优势了。

下面就以中文文本的处理为例进行说明,比如有一个字符串"测试文本",我们想要把这个中文字符串拆成单个字符,可以这样写:

use Encode;
$dat="测试文本";
$str=decode("gb2312",$dat);
@chars=split //,$str;
foreach $char (@chars) {
print encode("gb2312",$char),"\n";
}

结果大家试一试就知道了,应该是令人满意的。

这里主要用到了Encode模块的decode、encode函数。要了解这两个函数的作用我们需要清楚几个概念:

1、Perl字符串是使用utf8编码的,它由Unicode字符组成而不是单个字节,每个utf8编码的Unicode字符占1~4个字节(变长)。

2、进入或离开Perl处理环境(比如输出到屏幕、读入和保存文件等等)时不是直接使用Perl字符串,而需要把Perl字符串转换成字节流,转换过程中使用何种编码方式完全取决于你(或者由Perl代劳)。一旦Perl字符串向字节流的编码完成,字符的概念就不存在了,变成了纯粹的字节组合,如何解释这些组合则是你自己的工作。

我们可以看出如果想要Perl按照我们的字符概念来对待文本,文本数据就需要一直用Perl字符串的形式存放。但是我们平时写出的每个字符一般都被作为纯ASCII字符保存(包括在程序中明文写出的字符串),也就是字节流的形式,这里就需要encode和decode函数的帮助了。

encode函数顾名思义是用来编码Perl字符串的。它将Perl字符串中的字符用指定的编码格式编码,最终转化为字节流的形式,因此和Perl处理环境之外的事物打交道经常需要它。其格式很简单:
$octets = encode(ENCODING, $string [, CHECK])

$string:  Perl字符串
encoding: 是给定的编码方式
$octets:  是编码之后的字节流
check:   表示转换时如何处理畸变字符(也就是Perl认不出来的字符)。一般不需使用

编码方式视语言环境的不同有很大变化,默认可以识别utf8、ascii、ascii-ctrl、
iso-8859-1等。

decode函数则是用来解码字节流的。它按照你给出的编码格式解释给定的字节流,将其转化为使用utf8编码的Perl字符串,一般来说从终端或者文件取得的文本数据都应该用decode转换为Perl字符串的形式。它的格式为:

$string = decode(ENCODING, $octets [, CHECK])
$string、ENCODING、$octets和CHECK的含义同上。

现在就很容易理解上面写的那段程序了。因为字符串是用明文写出的,存放的时候已经是字节流形式,丧失了本来的意义,所以首先就要用 decode函数将其转换为Perl字符串,由于汉字一般都用gb2312格式编码,这里decode也要使用gb2312编码格式。转换完成后Perl 对待字符的行为就和我们一样了,平时对字符串进行操作的函数基本上都能正确对字符进行处理,除了那些本来就把字符串当成一堆字节的函数(如vec、 pack、unpack等)。于是split就能把字符串切成单个字符了。最后由于在输出的时候不能直接使用utf8编码的字符串,还需要将切割后的字符用encode函数编码为gb2312格式的字节流,再用print输出。
分享到:
评论

相关推荐

    perl程序实现对UTF16编码的文件转换为utf8编码文件

    一些文件是uff16格式,虽然也是文本类型文件,但读取总是出现乱码,因此写了一个程序,可实现对UTF16编码的文件转换为utf8编码文件,请大家下载之前查清楚自己遇到的文件是否是utf16格式的.否则无效哦.使用方法请打开脚本...

    Perl_and_unicode_and_encode-源码.rar

    在这个"Perl_and_unicode_and_encode-源码.rar"压缩包中,我们可以期待找到关于Perl如何处理Unicode字符和编码转换的相关源码示例。Unicode是现代软件和互联网中用于表示世界上几乎所有文字的标准,而Perl中的编码...

    Perl_and_unicode_and_encode:Kichijoji.pm Mini 006“ Perl,Unicode,Encode

    Kichijoji.pm迷你“ Perl,Unicode,Encode”的简历基础知识字符集,编码和字形(字体)不同的。小心!参考Perlunitut.pod Perluniintro.pod perlunicode.pod perlunifaq.pod第一步注意)请将以下所有源代码保存在...

    perl-Encode-HanExtra

    `perl-Encode-HanExtra` 是一个专门用于增强Perl对汉字编码处理能力的扩展库,它为Perl的内建`Encode`模块提供了更多针对中文字符集的支持。这个库的出现,极大地方便了开发人员在处理汉字编码问题时的工作,特别是...

    Perl用Post方法从新浪查天气

    ### Perl使用POST方法从新浪查询天气 在本篇教程中,我们将探讨如何使用Perl语言结合...通过对上述脚本的学习,可以了解到Perl在网络编程中的强大功能以及如何处理复杂的字符编码问题。希望这些知识点能对你有所帮助。

    Base62 Encode/Decode Utility:用于对base62进行编码/解码的工具-开源

    chewingum软件包包含两个主要程序:-base62-chew它们已在perl中实现。 Base62也已经用c ++编码。 嚼被写成缩短长的十进制整数到base62字符串。 这不是单纯的基本转换,因为它在逻辑内部不使用算术运算。 这样,它...

    conv2047:RFC 2047 Unicode 电子邮件标头字段转换器

    它基于 Encode Perl 模块。 Usage: conv2047.pl [-c] -d conv2047.pl -e The program reads header lines from standard input and tries to decode or encode them. Operation modes: -d decode (MIME-Header...

    Net-IDN-Encode (perl modules)-开源

    总结来说,Net-IDN-Encode是Perl编程环境中处理IDNs的重要工具,它提供了对Punycode转换的全面支持,并遵循了最新的IDNA标准。作为开源软件,它促进了技术交流和进步,为开发者提供了便捷的解决方案,使非ASCII字符...

    Encode-Simple:编码

    use Encode::Simple qw(encode encode_lax encode_utf8 decode decode_lax decode_utf8); my $bytes = encode 'Shift_JIS', $characters; my $bytes = encode_lax 'ASCII', $characters; my $bytes = encode_utf8 $...

    JSON-PP:Perl核心模块的JSON :: PP

    JSON-PP是Perl编程语言中的一个核心模块,用于处理JSON(JavaScript Object Notation)数据格式。JSON是一种轻量级的数据交换格式,因其简洁和高效,被广泛应用于Web服务和多种编程语言之间的数据交互。JSON-PP是...

    php json类

    JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,它采用完全独立于语言的文本格式,但也使用了类似于C家族语言的习惯,包括C、C++、C#、Java、JavaScript、Perl、Python等。PHP从5.2版本开始内置了...

    perl_utf8_cheat_sheet

    Perl是一种强大的脚本编程语言,尤其在处理文本和正则表达式方面表现出色。UTF-8是Unicode编码的一种实现方式,广泛用于存储和处理多语言字符。`perl_utf8_cheat_sheet`是一个针对Perl中处理UTF-8编码的快速参考指南...

    mongo-perl-bson-xs:BSON规范的Perl XS实现-http:bsonspec.org

    3. **创建 BSON 对象**:使用模块提供的方法,如 `encode_bson()` 和 `decode_bson()`,将 Perl 数据结构转换为 BSON 字节流或反之。 4. **操作 MongoDB**:在与 MongoDB 交互时,可以利用 `BSON::XS` 的对象作为...

    baudot_perl

    在处理Baudot码时,Perl程序可能定义了一些内部变量来存储编码映射,并提供了一些函数,比如`encode_baudot()`和`decode_baudot()`,来执行编码和解码过程。这些函数可能使用Perl的条件语句(if/elsif/else)和循环...

    如何处理UTF8格式的字符?

    在Perl编程语言中,处理UTF8格式的字符是一项常见的任务,因为UTF8是现代编码标准,广泛用于存储和传输多语言文本。以下是一份详细的指南,涵盖了如何在Perl中有效地处理UTF8字符。 首先,理解UTF8编码是关键。UTF8...

    mongo-perl-bson:BSON规范的Perl实现http://bsonspec.org

    例如,你可以使用 `BSON::encode` 函数将 Perl 数据结构转换为 BSON 字节,然后使用 `BSON::decode` 将这些字节反序列化回 Perl 数据结构。此外,`mongo-perl-bson` 还支持自定义的编码和解码逻辑,允许你扩展其功能...

    基于PHP的风吟PHPUnicode编码转换程序源码.zip

    3. **json_encode() 和 json_decode()**:在处理JSON数据时,这两个函数非常常用。JSON支持Unicode编码,`json_encode()`会将PHP变量转化为JSON格式的字符串,而`json_decode()`则将JSON字符串转化为PHP变量。在JSON...

    hashids.pm:Hashids,移植到Perl

    3. **编码与解码**:`hashids` 对象提供了 `encode` 和 `decode` 方法。`encode` 方法接受一个或多个整数,返回它们的编码字符串。相反,`decode` 方法接受一个编码字符串,返回原始的整数数组。例如: ```perl my...

    在PHP语言中使用JSON

    PHP从5.2版本开始原生支持JSON,通过内置的`json_encode()`和`json_decode()`两个函数实现对JSON数据的编码和解码操作。 1. `json_encode()`函数: 这个函数主要用于将PHP中的数组或对象转换成JSON格式的字符串。...

    PHP实现的json类实例

    JSON是完全独立于语言的文本格式,但是它采用了C家族语言程序员熟悉的公约,包括C、C++、C#、Java、JavaScript、Perl、TCL等。 2. JSON在PHP中的应用:在PHP中,JSON格式可以通过内置的json_encode()函数将PHP变量...

Global site tag (gtag.js) - Google Analytics