成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Encode模塊中兩大函數實現不同編碼之間的轉換

開發 架構
Perl編程語言有很多值得學習的地方,本文向大家簡單介紹一下Perl不同編碼之間的變換, 主要用到Encode模塊的decode、encode函數。

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

Perl不同編碼之間的變換

Perl從5.6開始已經開始在內部使用utf8編碼來表示字符,也就是說對中文以及其他語言字符的處理應該是完全沒有問題的。我們只需要利用好Encode這個模塊便能充分發揮Perl的utf8字符的優勢了。
下面就以中文文本的處理為例進行說明,比如有一個字符串”測試文本”,我們想要把這個中文字符串拆成單個字符,可以這樣寫:

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

 結果大家試一試就知道了,應該是令人滿意的。

這里主要用到了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輸出。

另外,還可以用下面的方法來"猜"出字符串的編碼.但我試過,也不是每次都管用.
 

  1. useEncodeqw/from_to/;  
  2. useEncode::Guessqw/euc-jpshiftjis/;  
  3. openINFILE"....";#輸入的文件是SHIFT-JIS編碼的文件這里只轉換第一行做個測試  
  4. my$str=<INFILE> 
  5. my$enc=guess_encoding($str);  
  6. if(ref$enc){  
  7. $from=$enc->name;  
  8. }else{  
  9. $from="shiftjis";  
  10. }  
  11. from_to($str,$from,$to);  
  12. printSTDOUT"ThetestStringis:$str";  

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

本文來自CSDN博客,轉載請標明出處:http://blog.csdn.net/dreamnear/archive/2007/11/07/1871662.aspx

【編輯推薦】

  1. 解析Perl map函數使用
  2. 專家答疑 Perl常見問題匯總
  3. Perl語言中Perl調試概述
  4. Perl語法 解析Perl變量使用
  5. 技術分享 解析Perl模塊創建和導入方法
責任編輯:佚名 來源: csdn.net
相關推薦

2010-04-01 09:34:06

Oracle函數

2010-07-15 14:25:06

Perl時間函數

2010-07-19 12:57:13

Perl

2010-08-30 10:03:13

2009-07-20 09:27:42

IBATIS.netDAO

2010-05-04 14:30:45

Oracle數據

2011-08-10 08:55:28

項目失敗

2011-12-28 10:49:44

Silverlight

2010-10-09 11:25:12

JS打印

2009-11-30 16:55:10

微軟合作Novell

2011-07-01 10:42:51

IIS解析漏洞

2022-03-01 18:23:17

架構大數據系統

2013-09-09 11:14:30

2022-02-24 08:00:00

API混合云數據

2011-11-02 09:35:34

虛擬化虛擬化管理

2011-08-11 09:41:38

2009-08-14 15:07:00

C#編譯過程

2011-01-07 09:36:22

NullMySQL

2010-09-10 09:42:37

borderclearCSS

2025-02-28 08:16:14

Spring框架注解
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 一级在线免费观看 | 一区二区三区在线观看视频 | 99久久婷婷国产综合精品电影 | 黄a网站 | 久久在线 | 国产乱码一二三区精品 | 国产福利网站 | 国产日韩欧美在线 | 一级看片免费视频囗交动图 | 日韩在线精品视频 | 一区二区精品在线 | 国产精品成人在线观看 | 国产精品成人久久久久 | 久久综合九色综合欧美狠狠 | 亚洲成人精品 | 成人夜晚看av | 欧美精品三区 | 精品国产一区一区二区三亚瑟 | 国产成人精品亚洲日本在线观看 | 欧美性生交大片免费 | www日本高清 | 人人九九精 | 大乳boobs巨大吃奶挤奶 | 中文字幕高清免费日韩视频在线 | 一二三四av | 久久一级免费视频 | 色视频成人在线观看免 | 日本激情一区二区 | 亚洲一区中文 | 国产电影一区二区 | 九九精品影院 | 国产在线视频一区 | 99视频网| 亚洲欧美日韩中文字幕一区二区三区 | 午夜男人天堂 | 精品欧美一区免费观看α√ | 美女黄视频网站 | 99免费在线观看视频 | av一区在线| 羞羞的视频免费在线观看 | 性色av网站 |