自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Perl不同編碼之間的變換

開發(fā) 架構(gòu)
Perl語言有很多值得學(xué)習(xí)的地方,你對Perl不同編碼之間的轉(zhuǎn)換是否熟悉,這里和大家簡單分享一下,希望本文的介紹能讓你有所收獲。

本文和大家重點(diǎn)討論一下Perl不同編碼之間的變換,Perl從5.6開始已經(jīng)開始在內(nèi)部使用utf8編碼來表示字符,也就是說對中文以及其他語言字符的處理應(yīng)該是完全沒有問題的。

Perl不同編碼之間的變換

Perl從5.6開始已經(jīng)開始在內(nèi)部使用utf8編碼來表示字符,也就是說對中文以及其他語言字符的處理應(yīng)該是完全沒有問題的。我們只需要利用好Encode這個模塊便能充分發(fā)揮Perl的utf8字符的優(yōu)勢了。

下面就以中文文本的處理為例進(jìn)行說明,比如有一個字符串”測試文本”,我們想要把這個中文字符串拆成單個字符,可以這樣寫:

 

  1. useEncode;  
  2. $dat=”測試文本”;  
  3. $str=decode(”gb2312″,$dat);  
  4. @chars=split//,$str;  
  5. foreach$char(@chars){  
  6. printencode(”gb2312″,$char),”\n”;  
  7. }  

 

結(jié)果大家試一試就知道了,應(yīng)該是令人滿意的。

這里主要用到了Encode模塊的decode、encode函數(shù)。要了解這兩個函數(shù)的作用我們需要清楚幾個概念:

1、Perl字符串是使用utf8編碼的,它由Unicode字符組成而不是單個字節(jié),每個utf8編碼的Unicode字符占1~4個字節(jié)(變長)。

2、進(jìn)入或離開Perl處理環(huán)境(比如輸出到屏幕、讀入和保存文件等等)時不是直接使用Perl字符串,而需要把Perl字符串轉(zhuǎn)換成字節(jié)流,轉(zhuǎn)換過程中使用何種編碼方式完全取決于你(或者由Perl代勞)。一旦Perl字符串向字節(jié)流的編碼完成,字符的概念就不存在了,變成了純粹的字節(jié)組合,如何解釋這些組合則是你自己的工作。

我們可以看出如果想要Perl按照我們的字符概念來對待文本,文本數(shù)據(jù)就需要一直用Perl字符串的形式存放。但是我們平時寫出的每個字符一般都被作為純ASCII字符保存(包括在程序中明文寫出的字符串),也就是字節(jié)流的形式,這里就需要encode和decode函數(shù)的幫助了。

encode函數(shù)顧名思義是用來編碼Perl字符串的。

它將Perl字符串中的字符用指定的編碼格式編碼,最終轉(zhuǎn)化為字節(jié)流的形式,因此和Perl處理環(huán)境之外的事物打交道經(jīng)常需要它。其格式很簡單:
$octets=encode(ENCODING,$string[,CHECK])

$string:  Perl字符串
encoding: 是給定的編碼方式
$octets:  是編碼之后的字節(jié)流
check:   表示轉(zhuǎn)換時如何處理畸變字符(也就是Perl認(rèn)不出來的字符)。一般不需使用編碼方式視語言環(huán)境的不同有很大變化,默認(rèn)可以識別utf8、ascii、ascii-ctrl、iso-8859-1等。

decode函數(shù)則是用來解碼字節(jié)流的。

它按照你給出的編碼格式解釋給定的字節(jié)流,將其轉(zhuǎn)化為使用utf8編碼的Perl字符串,一般來說從終端或者文件取得的文本數(shù)據(jù)都應(yīng)該用decode轉(zhuǎn)換為Perl字符串的形式。它的格式為:
$string=decode(ENCODING,$octets[,CHECK])
$string、ENCODING、$octets和CHECK的含義同上。

現(xiàn)在就很容易理解上面寫的那段程序了。因?yàn)樽址怯妹魑膶懗龅?,存放的時候已經(jīng)是字節(jié)流形式,喪失了本來的意義,所以首先就要用decode函數(shù)將其轉(zhuǎn)換為Perl字符串,由于漢字一般都用gb2312格式編碼,這里decode也要使用gb2312編碼格式。轉(zhuǎn)換完成后Perl對待字符的行為就和我們一樣了,平時對字符串進(jìn)行操作的函數(shù)基本上都能正確對字符進(jìn)行處理,除了那些本來就把字符串當(dāng)成一堆字節(jié)的函數(shù)(如vec、pack、unpack等)。于是split就能把字符串切成單個字符了。最后由于在輸出的時候不能直接使用utf8編碼的字符串,還需要將切割后的字符用encode函數(shù)編碼為gb2312格式的字節(jié)流,再用print輸出。

另外,還可以用下面的方法來"猜"出字符串的編碼.但我試過,也不是每次都管用.
useEncodeqw/from_to/;
useEncode::Guessqw/euc-jpshiftjis/;

openINFILE"....";#輸入的文件是SHIFT-JIS編碼的文件這里只轉(zhuǎn)換第一行做個測試
 

  1. my$str=<INFILE> 
  2. my$enc=guess_encoding($str);  
  3. if(ref$enc){  
  4. $from=$enc->name;  
  5. }else{  
  6. $from="shiftjis";  
  7. }  
  8.  
  9. from_to($str,$from,$to);  
  10. printSTDOUT"ThetestStringis:$str";  
  11.  

 當(dāng)輸入文件行紀(jì)錄是日文漢字開頭的時候,是可以判斷出來編碼類型是shift-jis的.但是當(dāng)開頭是一組數(shù)據(jù)再加個逗號之類的數(shù)據(jù)時,就猜不到了.原因還不是很明確.

本文來自CSDN博客,轉(zhuǎn)載請標(biāo)明出處:http://blog.csdn.net/dreamnear/archive/2007/11/07/1871662.aspx

【編輯推薦】

  1. Perl函數(shù)手冊專家指導(dǎo)
  2. Perl文件句柄概念詳解
  3. 解析兩大Perl標(biāo)量的操作符
  4. Perl基礎(chǔ) Perl數(shù)組學(xué)習(xí)指南
  5. Perl基礎(chǔ) 解析Perl標(biāo)量和數(shù)組概念
責(zé)任編輯:佚名 來源: csdn.net
相關(guān)推薦

2010-07-21 10:25:50

Perl

2010-01-20 11:15:38

CC++編譯器

2012-09-21 09:31:48

Linux服務(wù)器Windows

2012-08-01 14:08:06

IBMdW

2019-09-22 22:11:48

寬帶路由器子網(wǎng)

2012-04-27 09:24:44

程序員編碼員

2009-02-19 15:40:00

Linux不同網(wǎng)段訪問

2010-07-13 12:50:47

Perl變量

2010-07-13 14:26:11

Perl數(shù)組

2012-06-08 03:36:30

C#Java

2010-02-26 13:34:50

WCF編碼機(jī)制

2010-07-19 15:37:48

Perl日期時間

2009-04-30 09:28:05

SynonymOpenquerySQL Server

2010-07-21 14:18:27

Perl函數(shù)

2010-07-20 10:23:24

Perl類

2010-07-19 10:01:57

Perl函數(shù)

2010-07-20 14:41:55

Perl語法

2010-07-20 16:05:07

Perl包

2011-05-18 10:36:21

數(shù)據(jù)庫數(shù)據(jù)導(dǎo)入

2010-07-13 16:34:34

Perl 哈希表
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號