我试图按日期过滤 Dataframe ,但对于“2019-11-01 10:15:00”这样的日期,用表达式like this过滤 Dataframe 会很麻烦。
我的目标是做一些类似python version的东西:
use polars::export::chrono::NaiveDateTime;
use polars::prelude::*;
fn main() -> Result<(), Box<dyn std::error::Error>> {
let df = LazyCsvReader::new(path)
.with_parse_dates(true)
.has_header(true)
.finish()?
.collect()?;
let dt = NaiveDateTime::parse_from_str("2019-11-01 10:15:00", "%Y-%m-%d %H:%M:%S")?;
//This will not compile!
let filtered = df.filter(col("time") < dt);
}
然而,我有一个非常困难的时间来过滤日期框到位或只是创建一个布尔掩码。
1条答案
按热度按时间oknwwptz1#
经过更多的时间,我不敢承认我终于解决了它使用渴望API,可能有一个更好的解决方案在懒惰API,但这工程现在!
要从“time”列获取日期值并将其解析为NaiveDateTime: