- 浏览: 581129 次
- 性别:
- 来自: 深圳
文章分类
- 全部博客 (200)
- html css (6)
- javascript (11)
- php (6)
- java基础 (18)
- mysql (8)
- ssh (7)
- linux (21)
- 杂想 (1)
- 搜索引擎 (2)
- linux-shell (2)
- perl (61)
- 单元测试 (1)
- jquery (1)
- xml (1)
- 求职招聘 (1)
- 其他 (2)
- 项目工具 (2)
- maven (10)
- ant (1)
- eclipse (3)
- windows (4)
- java (8)
- jsp (1)
- c c++ (7)
- java-web (3)
- 汇编 (1)
- 正则表达式 (2)
- 网络 (1)
- 路由 (1)
- ip (1)
- 测试驱动开发 (1)
- tdd (1)
- vim (1)
- powermock (1)
- junit (1)
- spring (1)
- spring security (1)
- httpclient (1)
- sql (1)
- sqlserver (2)
- 存储过程 (1)
- apache (1)
- Nexus (1)
- 金融 (1)
- clojure (4)
- 函数式编程 (3)
- 工作 (1)
- git (2)
- java 并发 (1)
- python (1)
- java netty proxy (1)
- scala (1)
最新评论
-
springmvc-freemarker:
可以参考最新的文档:如何在eclipse jee中检出项目并转 ...
eclipse 配置maven web项目 -
zk1878:
huzhenyu 写道楼主很用心,讲得十分清楚,非常实用!呵呵 ...
eclipse 配置maven web项目 -
huzhenyu:
楼主很用心,讲得十分清楚,非常实用!
eclipse 配置maven web项目 -
宋建勇:
不错,对CountDownLatch了解加深了!
java 多线程 CountDownLatch用法 -
zk1878:
必须的。。。。
perl下载图片
原文:http://www.cnblogs.com/slaughter/archive/2007/03/15/675791.html
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 http模块总结
2013-04-04 23:51 5790perl发送http请求主要有 LWP,UserAgent ... -
perl json
2013-04-03 20:51 4123http://search.cpan.org/~makam ... -
perl xml json
2012-09-14 19:52 1301use XML::XML2JSON; ... -
perl源文件编码类型导致乱码问题
2012-09-11 09:28 2326$str = '中国'; chdir 'E:\jo ... -
perl 解析html, 自己写的几个比较常用方法
2012-09-04 20:56 7210perl解析html, 比较常用的模块是 HTML::Tree ... -
perl多进程示例
2012-08-17 15:33 1947以下例子,在主进程生成3个子进程,然后再收割每个子进程,防 ... -
一段实用的perl脚本
2012-08-15 20:53 2371下面的脚本实现了在命令行直接执行perl语句或是执行 ... -
perl发送http请求,easy之极
2012-08-09 23:21 15995perl 发送http 非常之简单,发送get请求 只一 ... -
perl 操作mysql
2012-04-27 07:57 1185use DBI; @driver_names = ... -
Perl 中的线程
2012-03-31 22:19 1483原文:http://www.ibm.com/developer ... -
perl smtp 发送邮件
2012-03-20 23:44 4990原文:http://blog.chinaunix.net/ui ... -
perl开启并关闭w32进程
2012-03-05 16:31 1984perl是个很强大的脚本语言,cpan包罗万象的 ... -
perl发送http请求
2012-02-16 17:51 5217下面是一段perl发送http请求的代码,设置了请求头,表单参 ... -
perl对windows的进程的一些常用操作
2012-02-16 17:52 20671、获取所有正在运行的进程,用到了cpan的Win32::Pr ... -
perl查看已经安装的模块
2012-02-16 17:53 1409use ExtUtils::Installed; my ... -
在Perl调用C/C++代码/动态链接库
2012-02-10 17:46 6421原文http://manew.org/?p=62 perl想 ... -
perl 剪贴板操作
2012-02-09 14:05 1665以下代码设置剪贴板内容为 hello world,然后读取剪贴 ... -
perl 文件目录的创建删除拷贝
2012-01-11 18:03 5285以下三个是核心包提供的 1 unlink @files ... -
perl正则表达式中该注意的一个问题
2011-12-29 00:06 1218请看以下例子 代码1 $a='abc123EEE11 ... -
perl 目录遍历
2011-12-16 10:27 2396使用perl的 File::Find模块,目录遍历将会很简单, ...
相关推荐
一些文件是uff16格式,虽然也是文本类型文件,但读取总是出现乱码,因此写了一个程序,可实现对UTF16编码的文件转换为utf8编码文件,请大家下载之前查清楚自己遇到的文件是否是utf16格式的.否则无效哦....
例如,`encode('GBK', $utf8_string)`可以将UTF-8编码的字符串转换为GBK编码,而`decode('GBK', $gbk_string)`则可以完成相反的转换。这样,无论数据源的编码格式如何,我们都可以通过这个库进行统一处理。 此外,`...
在这个"Perl_and_unicode_and_encode-源码.rar"压缩包中,我们可以期待找到关于Perl如何处理Unicode字符和编码转换的相关源码示例。Unicode是现代软件和互联网中用于表示世界上几乎所有文字的标准,而Perl中的编码...
Kichijoji.pm迷你“ Perl,Unicode,Encode”的简历基础知识字符集,编码和字形(字体)不同的。小心!参考Perlunitut.pod Perluniintro.pod perlunicode.pod perlunifaq.pod第一步注意)请将以下所有源代码保存在...
$city = encode("gbk", decode("utf8", $city)); my $c = &do_POST("http://php.weather.sina.com.cn/search.php", [type => "text", city => $city], ) or die "Cannot get weather information\n"; $c =~ s/gb...
它基于 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...
chewingum软件包包含两个主要程序:-base62-chew它们已在perl中实现。 Base62也已经用c ++编码。 嚼被写成缩短长的十进制整数到base62字符串。 这不是单纯的基本转换,因为它在逻辑内部不使用算术运算。 这样,它...
例如,`encode_idna()` 函数可以将一个IDN字符串转化为Punycode,而 `decode_idna()` 可以执行相反的操作。此外,该模块还提供了其他辅助函数,如检测非法字符、进行规则检查等,确保了IDN的正确性和合规性。 开源...
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时,开发者通常需要导入模块,然后调用`decode_json`和`encode_json`函数。例如: ```perl use JSON::PP; my $json_text = '{"key": "value"}'; my $perl_data = decode_json($json_text); # 或者 my...
- `Encode::decode('UTF-8', $data, Encode::FB_WARN);` 会发出警告,如果数据不是有效的UTF-8。 - `Encode::decode('UTF-8', $data, Encode::FB die);` 会在失败时抛出异常。 7. **模块推荐**: - `Text::...
3. **创建 BSON 对象**:使用模块提供的方法,如 `encode_bson()` 和 `decode_bson()`,将 Perl 数据结构转换为 BSON 字节流或反之。 4. **操作 MongoDB**:在与 MongoDB 交互时,可以利用 `BSON::XS` 的对象作为...
例如,你可以使用 `BSON::encode` 函数将 Perl 数据结构转换为 BSON 字节,然后使用 `BSON::decode` 将这些字节反序列化回 Perl 数据结构。此外,`mongo-perl-bson` 还支持自定义的编码和解码逻辑,允许你扩展其功能...
3. **编码与解码**:`hashids` 对象提供了 `encode` 和 `decode` 方法。`encode` 方法接受一个或多个整数,返回它们的编码字符串。相反,`decode` 方法接受一个编码字符串,返回原始的整数数组。例如: ```perl my...
在处理Baudot码时,Perl程序可能定义了一些内部变量来存储编码映射,并提供了一些函数,比如`encode_baudot()`和`decode_baudot()`,来执行编码和解码过程。这些函数可能使用Perl的条件语句(if/elsif/else)和循环...
JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,它采用完全独立于语言的文本格式,但也使用了类似于C家族语言的习惯,包括C、C++、C#、Java、JavaScript、Perl、Python等。PHP从5.2版本开始内置了...
这个模块提供了`encode_base64`和`decode_base64`两个函数,分别用于编码和解码。 首先,让我们深入了解Base64编码的工作原理。Base64编码是基于64个字符的字符集,包括大小写字母(A-Z,a-z),数字(0-9)以及"+...
名称Image :: LibSIXEL-libsixel的Perl接口(DEC SIXEL图形编解码器的轻量级,快速实现)概要 use Image::LibSIXEL; $encoder = Image::LibSIXEL::Encoder->new(); $encoder->setopt("w", 400); $encoder->setopt("p...
JSON基于JavaScript的一个子集,但其格式是独立于任何编程语言的,尽管它借鉴了C语言家族(如C、C++、C#、Java、JavaScript、Perl、Python等)的语法习惯。由于这些特点,JSON成为了理想的数据交互语言,尤其在网络...
使用`Encode::decode`或`Encode::encode`时,可以设置`die_on_error`参数来使程序在检测到错误时立即终止,或者设置`replace`参数来替换非法序列。 总之,在Perl中处理UTF8字符涉及多个层面,包括文件I/O、字符串...