Ruby 2.4

Encoding::InvalidByteSequenceError

class Encoding::InvalidByteSequenceError

Parent:rb_eEncodingError

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

公共实例方法

destination_encoding → string Show source

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

static VALUE ecerr_destination_encoding(VALUE self) { return rb_attr_get(self, rb_intern("destination_encoding") }

destination_encoding_name → string Show source

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

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时,返回丢弃的字节。

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

static VALUE ecerr_error_bytes(VALUE self) { return rb_attr_get(self, rb_intern("error_bytes") }

incomplete_input? → true or false Show source

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

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

static VALUE ecerr_incomplete_input(VALUE self) { return rb_attr_get(self, rb_intern("incomplete_input") }

readagain_bytes → string Show source

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

static VALUE ecerr_readagain_bytes(VALUE self) { return rb_attr_get(self, rb_intern("readagain_bytes") }

source_encoding → encoding Show source

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

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

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

static VALUE ecerr_source_encoding(VALUE self) { return rb_attr_get(self, rb_intern("source_encoding") }

source_encoding_name → string Show source

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

static VALUE ecerr_source_encoding_name(VALUE self) { return rb_attr_get(self, rb_intern("source_encoding_name") }