polars_core/frame/
upstream_traits.rsuse std::ops::{Index, Range, RangeFrom, RangeFull, RangeInclusive, RangeTo, RangeToInclusive};
use arrow::record_batch::RecordBatchT;
use crate::prelude::*;
impl FromIterator<Series> for DataFrame {
fn from_iter<T: IntoIterator<Item = Series>>(iter: T) -> Self {
let v = iter.into_iter().map(Column::from).collect();
DataFrame::new(v).expect("could not create DataFrame from iterator")
}
}
impl FromIterator<Column> for DataFrame {
fn from_iter<T: IntoIterator<Item = Column>>(iter: T) -> Self {
let v = iter.into_iter().collect();
DataFrame::new(v).expect("could not create DataFrame from iterator")
}
}
impl TryExtend<RecordBatchT<Box<dyn Array>>> for DataFrame {
fn try_extend<I: IntoIterator<Item = RecordBatchT<Box<dyn Array>>>>(
&mut self,
iter: I,
) -> PolarsResult<()> {
for record_batch in iter {
self.append_record_batch(record_batch)?;
}
Ok(())
}
}
impl TryExtend<PolarsResult<RecordBatchT<Box<dyn Array>>>> for DataFrame {
fn try_extend<I: IntoIterator<Item = PolarsResult<RecordBatchT<Box<dyn Array>>>>>(
&mut self,
iter: I,
) -> PolarsResult<()> {
for record_batch in iter {
self.append_record_batch(record_batch?)?;
}
Ok(())
}
}
impl Index<usize> for DataFrame {
type Output = Column;
fn index(&self, index: usize) -> &Self::Output {
&self.columns[index]
}
}
macro_rules! impl_ranges {
($range_type:ty) => {
impl Index<$range_type> for DataFrame {
type Output = [Column];
fn index(&self, index: $range_type) -> &Self::Output {
&self.columns[index]
}
}
};
}
impl_ranges!(Range<usize>);
impl_ranges!(RangeInclusive<usize>);
impl_ranges!(RangeFrom<usize>);
impl_ranges!(RangeTo<usize>);
impl_ranges!(RangeToInclusive<usize>);
impl_ranges!(RangeFull);
impl Index<&str> for DataFrame {
type Output = Column;
fn index(&self, index: &str) -> &Self::Output {
let idx = self.check_name_to_idx(index).unwrap();
&self.columns[idx]
}
}