位置: 编程技术 - 正文

perl 中文处理技巧(perl语言)

编辑:rootadmin
Perl从5.6开始已经开始在内部使用utf8编码来表示字符,也就是说对中文以及其他语言字符的处理应该是完全没有问题的。我们只需要利用好Encode这个模块便能充分发挥Perl的utf8字符的优势了。 下面就以中文文本的处理为例进行说明,比如有一个字符串"测试文本",我们想要把这个中文字符串拆成单个字符,可以这样写: use Encode; $dat="测试文本"; $str=decode("gb",$dat); @chars=split //,$str; foreach $char (@chars) { print encode("gb",$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--1等。 decode函数则是用来解码字节流的。它按照你给出的编码格式解释给定的字节流,将其转化为使用utf8编码的Perl字符串,一般来说从终端或者文件取得的文本数据都应该用decode转换为Perl字符串的形式。它的格式为: $string = decode(ENCODING, $octets [, CHECK]) $string、ENCODING、$octets和CHECK的含义同上。 现在就很容易理解上面写的那段程序了。因为字符串是用明文写出的,存放的时候已经是字节流形式,丧失了本来的意义,所以首先就要用 decode函数将其转换为Perl字符串,由于汉字一般都用gb格式编码,这里decode也要使用gb编码格式。转换完成后Perl 对待字符的行为就和我们一样了,平时对字符串进行操作的函数基本上都能正确对字符进行处理,除了那些本来就把字符串当成一堆字节的函数(如vec、 pack、unpack等)。于是split就能把字符串切成单个字符了。最后由于在输出的时候不能直接使用utf8编码的字符串,还需要将切割后的字符用encode函数编码为gb格式的字节流,再用print输出。

推荐整理分享perl 中文处理技巧(perl语言),希望有所帮助,仅作参考,欢迎阅读内容。

perl 中文处理技巧(perl语言)

文章相关热门搜索词:perl语言是干嘛的,perl处理文本,perl教程中文,perl language,perl language,perl中$_,perl教程中文,perl教程中文,内容如对您有帮助,希望把文章链接给更多的朋友!

perl 学习资料整理篇第1/4页 NULL值的判断$t{type1id}=$$pref{dbh}-selectrow_array("SELECTtype1idFROMenq1WHEREid=3");if($t{type1id}==0){print"Type1idisNULLn";}==不是数值项的话,这个语句有问题。数值项专用。i

只有一行的Perl程序第1/3页 1lineperl今天来说说perl,只有一行的perl程序。各种编程语言中perl是以变态的古灵精怪而闻名的,比如我,就经常写出自己都看不懂的perl程序来。比如这

关于Perl里面正则表达式规范 1,定界符=~m/there/;=~s/there/here/;还有类型的定界符:=~/there/=~m#there#;=~s#there#here#;=~m(there);=~s(there)(here);=~m{there};=~s{there}{here};=~m[there];=~s[there][here];=~m,there,;=~

标签: perl语言

本文链接地址:https://www.jiuchutong.com/biancheng/372438.html 转载请保留说明!

上一篇:perl中5个常见错误(perl cgi)

下一篇:perl 学习资料整理篇第1/4页(perl 教程)

  • 增值税税率改变后原项目的新增单价按哪个税率
  • 支付境外劳务费需要缴纳哪些税费
  • 烟叶税税率计算方法
  • 个人提供建筑安装劳务如何缴纳个人所得税
  • 发票第一联需要盖章嘛
  • 装修行业开票税率
  • 增值税季报是填3个月的收入吗
  • 境外中资企业转让股权的涉税处理
  • 以前年度管理费用多计
  • 股东货币出资比例
  • 汽车租赁油费怎么算
  • 房地产活动礼品送什么比较吸引人
  • 审计调整tb
  • 贸易类公司所得税核定征收税率是多少?
  • 跨地区预缴税款需缴纳哪些
  • 虚开增值税专用发票罪判决书
  • 消费税可以跨年计提吗
  • 会务费税前扣除比例
  • 纳税人转让2016年以后的土地使用权
  • 发票丢失可以抵扣吗
  • 财务软件利润表没显示
  • 有业务往来的两家公司可以投一个公司吗
  • 期间费用企业所得税扣除
  • 使用时间长但金币不见了
  • 从银行提取现金属于什么会计要素
  • 合伙人退伙资产清算需要交税吗
  • 终于找到修改mac的方法了!
  • 坏账准备年末余额怎么计算
  • 建筑业预缴企业所得税是分季预缴按年抵减吗
  • linux阅读pdf
  • 电脑上fci是什么文件
  • 取得的进项税发票抵扣
  • 会计的四大基本要素
  • 利润分配的账务处理如何做
  • 二手车价格网站
  • Laravel5权限管理方法详解
  • ps笔刷在哪里调
  • 支付中介费和物业费比例
  • 会计制度备案附件要上传什么
  • 利润表反映了什么能力
  • 有收入就要结转成本吗为什么
  • 小规模纳税人零申报可以持续多久
  • 金税盘减免税款分录
  • 公司给非本单位的个人转账有风险怎么平账
  • 增值税专用发票怎么开
  • 保险没有合同算生效吗
  • 报关单金额大于出口发票金额
  • 公司法人转账到公司账户
  • 开发间接费用的折旧包括哪些
  • 以前年度多计提了费用
  • 收到支持学校工作的短信怎么回复
  • 公司给别人公司过账应该注意哪些
  • 增值税转型不得超过多少
  • 公司与公司之间的函怎么写
  • 应收利息可以计提坏账准备吗
  • 医院收费单可以当发票吗
  • 股东将股权转让后是否还承担责任
  • unsecapp.exe - unsecapp是什么进程
  • win10预览版21301bug
  • osk.exe
  • Win7 vpn连接不上怎么办?Win7系统vpn连接不上问题的解决方法
  • unix & linux
  • windows11内测版
  • win10触屏操作
  • win10系统保留分区可以删除吗
  • 程序员用linux可以干什么
  • css display:none使用注意事项小结
  • attributes.add
  • windbg调试驱动
  • lint 工具
  • jqury选择器
  • 置顶语句子
  • android 加载大量图片
  • android开发框架mvp
  • 金税盘注销后怎么开发票
  • 河北电子税务局社保缴费流程
  • 电子办税服务厅怎么开电子发票
  • 杭州残保金2021年新政策申报时间
  • 什么叫售后回租赁合同
  • 道路坡度最大限度不超过多少度
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设