Expand description
§ptars
Fast conversion from Protocol Buffers to Apache Arrow and back.
This crate provides efficient conversion between Protocol Buffer messages and Apache Arrow record batches, enabling high-performance data processing pipelines that bridge the protobuf and Arrow ecosystems.
§Features
- Convert protobuf messages to Arrow RecordBatch
- Convert Arrow RecordBatch back to protobuf messages
- Support for nested messages, repeated fields, and maps
- Special handling for well-known types (Timestamp, Date, TimeOfDay, wrapper types)
§Example
ⓘ
use ptars::{binary_array_to_record_batch_direct, PtarsConfig};
use arrow_array::BinaryArray;
use prost_reflect::DescriptorPool;
// Load your protobuf descriptor
let pool = DescriptorPool::decode(descriptor_bytes).unwrap();
let message_descriptor = pool.get_message_by_name("my.Message").unwrap();
// Decode serialized protobuf messages directly to Arrow
let binary_array: BinaryArray = /* your serialized messages */;
let config = PtarsConfig::default();
let record_batch = binary_array_to_record_batch_direct(&binary_array, &message_descriptor, &config).unwrap();Re-exports§
pub use arrow_to_proto::record_batch_to_array;pub use config::EnumRepr;pub use config::PtarsConfig;pub use proto_to_arrow::binary_array_to_messages;pub use proto_to_arrow::binary_array_to_record_batch_direct;pub use proto_to_arrow::messages_to_record_batch;pub use proto_to_arrow::messages_to_record_batch_with_config;