Struct dbn::encode::csv::Encoder

source ·
pub struct Encoder<W>
where W: Write,
{ /* private fields */ }
Expand description

Type for encoding files and streams of DBN records in CSV or other text-delimited tabular file formats including TSV (tab-separated values).

Note that encoding Metadata in CSV is not supported.

Implementations§

source§

impl<W> Encoder<W>
where W: Write,

source

pub fn builder(writer: W) -> EncoderBuilder<W>

Creates a builder for configuring an Encoder object.

source

pub fn new(writer: W, use_pretty_px: bool, use_pretty_ts: bool) -> Self

Creates a new Encoder that will write to writer. If use_pretty_px is true, price fields will be serialized as a decimal. If pretty_ts is true, timestamp fields will be serialized in a ISO8601 datetime string.

source

pub fn get_ref(&self) -> &W

Returns a reference to the underlying writer.

source

pub fn encode_header<R: DbnEncodable>( &mut self, with_symbol: bool ) -> Result<()>

Encodes the CSV header for the record type R, i.e. the names of each of the fields to the output.

If with_symbol is true, will add a header field for “symbol”. This should only be used with Self::encode_record_with_sym() and Self::encode_ref_with_sym(), otherwise there will be a mismatch between the number of fields in the header and the body.

§Errors

This function returns an error if there’s an error writing to writer.

source

pub fn encode_header_for_schema( &mut self, schema: Schema, ts_out: bool, with_symbol: bool ) -> Result<()>

Encodes the CSV header for schema, i.e. the names of each of the fields to the output.

If ts_out is true, it will add a header field “ts_out”.

If with_symbol is true, it will add a header field for “symbol”. This should only be used with Self::encode_record_with_sym() and Self::encode_ref_with_sym(), otherwise there will be a mismatch between the number of fields in the header and the body.

§Errors

This function returns an error if there’s an error writing to writer.

Trait Implementations§

source§

impl<W> EncodeDbn for Encoder<W>
where W: Write,

source§

fn encode_stream<R: DbnEncodable>( &mut self, stream: impl FallibleStreamingIterator<Item = R, Error = Error> ) -> Result<()>

Encodes a stream of DBN records.

§Errors

This function returns an error if it’s unable to write to the underlying writer or there’s a serialization error.

source§

fn encode_decoded<D: DecodeRecordRef + DbnMetadata>( &mut self, decoder: D ) -> Result<()>

Encode DBN records directly from a DBN decoder. This implemented outside EncodeDbn because the CSV encoder has the additional constraint of only being able to encode a single schema in a stream.

§Errors

This function returns an error if it’s unable to write to the underlying writer or there’s a serialization error.

source§

fn encode_records<R: DbnEncodable>(&mut self, records: &[R]) -> Result<()>

Encodes a slice of DBN records. Read more
source§

fn encode_decoded_with_limit<D: DecodeRecordRef + DbnMetadata>( &mut self, decoder: D, limit: NonZeroU64 ) -> Result<()>

Encodes DBN records directly from a DBN decoder, outputting no more than limit records. Read more
source§

impl<W> EncodeRecord for Encoder<W>
where W: Write,

source§

fn encode_record<R: DbnEncodable>(&mut self, record: &R) -> Result<()>

Encodes a single DBN record of type R. Read more
source§

fn flush(&mut self) -> Result<()>

Flushes any buffered content to the true output. Read more
source§

impl<W> EncodeRecordRef for Encoder<W>
where W: Write,

source§

fn encode_record_ref(&mut self, record: RecordRef<'_>) -> Result<()>

Encodes a single DBN RecordRef. Read more
source§

unsafe fn encode_record_ref_ts_out( &mut self, record: RecordRef<'_>, ts_out: bool ) -> Result<()>

Encodes a single DBN RecordRef with an optional ts_out (see record::WithTsOut). Read more
source§

impl<W> EncodeRecordTextExt for Encoder<W>
where W: Write,

source§

fn encode_record_with_sym<R: DbnEncodable>( &mut self, record: &R, symbol: Option<&str> ) -> Result<()>

Encodes a single DBN record of type R along with the record’s text symbol. Read more
source§

fn encode_ref_with_sym( &mut self, record: RecordRef<'_>, symbol: Option<&str> ) -> Result<()>

Encodes a single DBN RecordRef along with the record’s text symbol. Read more
source§

unsafe fn encode_ref_ts_out_with_sym( &mut self, record: RecordRef<'_>, ts_out: bool, symbol: Option<&str> ) -> Result<()>

Encodes a single DBN RecordRef with an optional ts_out (see record::WithTsOut) along with the record’s text symbol. Read more

Auto Trait Implementations§

§

impl<W> Freeze for Encoder<W>
where W: Freeze,

§

impl<W> RefUnwindSafe for Encoder<W>
where W: RefUnwindSafe,

§

impl<W> Send for Encoder<W>
where W: Send,

§

impl<W> Sync for Encoder<W>
where W: Sync,

§

impl<W> Unpin for Encoder<W>
where W: Unpin,

§

impl<W> UnwindSafe for Encoder<W>
where W: UnwindSafe,

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<T> Ungil for T
where T: Send,