Iconv是UNIX 95的iconv()函数的封装形式,它在各种字符代码体系间进行字符串转换。

Iconv

Iconv是UNIX 95的iconv()函数的封装形式,它在各种字符代码体系间进行字符串转换。

详情请参考Open Group的在线文档。

具体使用哪套字符代码体系要看系统而定。

Iconv 类

类方法

Iconv.new(to, from)

生成并返回从fromto的新的转换器。

tofrom分别指变换后和变换前的字符代码体系。

该方法中可能出现的异常如下。

tofrom不是String时,将引发TypeError

若找不到tofrom所指的变换器时,则引发ArgumentError

iconv_open(3)运行失败,则引发SystemCallError

Iconv.open(to, from) {|cd| ...}

若没给块时,它相当于Iconv.new。若给块的话,将计算块的内容,关闭转换器,并返回块的计算值。

Iconv.iconv(to, from, *strs)

它是下列语句

Iconv.open(to, from) {|cd| (strs + [nil]).collect {|s| cd.iconv(s)}}

的省略形式。其中tofrom的意义与Iconv.new中的相同。

strs是被变换的字符串。

该方法可能会引起Iconv.new, Iconv.open 以及 Iconv#iconv 中的异常。

Iconv.conv(to, from, str)

它是下列语句

Iconv.iconv(to, from, str).join

的省略形式。请参考Iconv.iconv

Iconv.list {|*aliases| ... } ((<ruby 1.9 特性>))

Iterates each alias sets. 若未指定块,则返回编码名列表。

实例方法

Iconv#close

结束转换。

若调用该方法之后再调用Iconv#iconv的话,就会引发异常。但若只调用close本身的话则没问题。

它的返回值是可以使输出缓冲区恢复到初始shift状态的字节串。

i = Iconv.open("ISO-2022-JP", "EUC-JP")
i.iconv("/264/301")     #=> "/e$B4A"
i.iconv("/273/372")     #=> ";z"
i.close                 #=> "/e(B"
Iconv#iconv(str, [ start = 0, [ length = -1 ] ])

开始转换字符串,并返回转换结果。

str是字符串,则进行str[start, length]转换,并返回转换结果。

strnil,则将转换器恢复到初始shift状态,并返回可将输出缓冲区恢复为初始shift状态的字节串。

除此以外将引发异常。

str是转换后的字符串或nil

startstr中的转换起始点。

lengthstr中的转换长度。若为nil-1的话,则指转换start后面的所有字符。

该方法可能会引发Iconv::IllegalSequenceIconv::InvalidCharacter、以及 Iconv::OutOfRange 异常。

Iconv::Failure 模块

Iconv可能引发的异常而设置的模块。

实例方法

Iconv::Failure#success

返回发生异常前转换成功的字符串。

Iconv.iconv 中发生该异常时的返回值是,由发生异常前转换成功的字符串所构成的数组。数组的最后一个元素就是变换中的字符串。

Iconv::Failure#failed

它返回传给Iconv的字符串中的异常发生点之后部分。

Iconv::Failure#inspect

返回形如#<type: "success", "failed">这样的字符串。

Iconv::IllegalSequence 类

它表示,因为输出或输入的字符不在指定的字符集合内,所以停止转换。

超类

ArgumentError

包含的模块

Iconv::Failure

Iconv::InvalidCharacter 类

它表示,因为输入的末尾部分是不完整的字符或shift,所以停止转换。

超类

ArgumentError

包含的类

Iconv::Failure

Iconv::OutOfRange 类

Iconv库的内部错误。通常不会引发该异常。

超类

RuntimeError

包含的模块

Iconv::Failure

  1. 新生成Iconv的实例,并使用Iconv#iconv方法

    cd = Iconv.new(to, from)
    begin
      input.each {|s| output << cd.iconv(s)}
      output << cd.iconv(nil)      # don't forget this
    ensure
      cd.close
    end
    
  2. 带块调用Iconv.open

    Iconv.open(to, from) do |cd|
      input.each {|s| output << cd.iconv(s)}
      output << cd.iconv(nil)
    end
    
  3. (2) 的简略形式

    Iconv.iconv(to, from, *input.to_a)
    

工具包下载

http://www.zlatkovic.com/pub/pub/libxml


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值