首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Encoding::InvalidByteSequenceError

Parent:rb_eEncodingError

当被转码的字符串包含对源或目标编码无效的字节时,由编码和字符串方法引发。

公共实例方法

destination_encoding → string Show source

作为编码对象返回目标编码。

代码语言:javascript
复制
static VALUE
ecerr_destination_encoding(VALUE self)
{
    return rb_attr_get(self, rb_intern("destination_encoding"));
}

destination_encoding_name → string Show source

以字符串形式返回目标编码名称。

代码语言:javascript
复制
static VALUE
ecerr_destination_encoding_name(VALUE self)
{
    return rb_attr_get(self, rb_intern("destination_encoding_name"));
}

error_bytes → string Show source

发生Encoding :: InvalidByteSequenceError时,返回丢弃的字节。

代码语言:javascript
复制
ec = Encoding::Converter.new("EUC-JP", "ISO-8859-1")
begin
  ec.convert("abc\xA1\xFFdef")
rescue Encoding::InvalidByteSequenceError
  p $!      #=> #<Encoding::InvalidByteSequenceError: "\xA1" followed by "\xFF" on EUC-JP>
  puts $!.error_bytes.dump          #=> "\xA1"
  puts $!.readagain_bytes.dump      #=> "\xFF"
end
代码语言:javascript
复制
static VALUE
ecerr_error_bytes(VALUE self)
{
    return rb_attr_get(self, rb_intern("error_bytes"));
}

incomplete_input? → true or false Show source

如果无效的字节序列错误是由于字符串过早结束引起的,则返回true。

代码语言:javascript
复制
ec = Encoding::Converter.new("EUC-JP", "ISO-8859-1")

begin
  ec.convert("abc\xA1z")
rescue Encoding::InvalidByteSequenceError
  p $!      #=> #<Encoding::InvalidByteSequenceError: "\xA1" followed by "z" on EUC-JP>
  p $!.incomplete_input?    #=> false
end

begin
  ec.convert("abc\xA1")
  ec.finish
rescue Encoding::InvalidByteSequenceError
  p $!      #=> #<Encoding::InvalidByteSequenceError: incomplete "\xA1" on EUC-JP>
  p $!.incomplete_input?    #=> true
end
代码语言:javascript
复制
static VALUE
ecerr_incomplete_input(VALUE self)
{
    return rb_attr_get(self, rb_intern("incomplete_input"));
}

readagain_bytes → string Show source

发生Encoding :: InvalidByteSequenceError时,返回要再次读取的字节。

代码语言:javascript
复制
static VALUE
ecerr_readagain_bytes(VALUE self)
{
    return rb_attr_get(self, rb_intern("readagain_bytes"));
}

source_encoding → encoding Show source

作为编码对象返回源编码。

请注意,如果转换具有多个步骤,结果可能不等于编码转换器的源编码。

代码语言:javascript
复制
ec = Encoding::Converter.new("ISO-8859-1", "EUC-JP") # ISO-8859-1 -> UTF-8 -> EUC-JP
begin
  ec.convert("\xa0") # NO-BREAK SPACE, which is available in UTF-8 but not in EUC-JP.
rescue Encoding::UndefinedConversionError
  p $!.source_encoding              #=> #<Encoding:UTF-8>
  p $!.destination_encoding         #=> #<Encoding:EUC-JP>
  p $!.source_encoding_name         #=> "UTF-8"
  p $!.destination_encoding_name    #=> "EUC-JP"
end
代码语言:javascript
复制
static VALUE
ecerr_source_encoding(VALUE self)
{
    return rb_attr_get(self, rb_intern("source_encoding"));
}

source_encoding_name → string Show source

以字符串形式返回源编码名称。

代码语言:javascript
复制
static VALUE
ecerr_source_encoding_name(VALUE self)
{
    return rb_attr_get(self, rb_intern("source_encoding_name"));
}

扫码关注腾讯云开发者

领取腾讯云代金券