3 个稳定版本
1.0.2 | 2020年6月6日 |
---|---|
1.0.1 | 2020年5月30日 |
1.0.0 | 2020年5月28日 |
58 在 #rss
17KB
218 行
future_rss
使用 Rust 序列化 Rss 结构。
用法
tokio = { version ="*", features = [ "macros","rt-core" ] }
future_rss = "*"
示例
解析 Xml
use future_rss::*;
#[tokio::main]
async fn main()->Result<(),Box<dyn std::error::Error>> {
let address = "https://www.zhihu.com/rss";
let mut parser = RssParser::from_url(address,"utf8").await?;
parser.author_tag = String::from("dc:creator");
let rss = parser.parse_vec().await?;
println!("{:?}",rss);
Ok(())
}
解析网络 Xml
use future_rss::RssParser;
#[tokio::main]
async fn main()->Result<(),Box<dyn std::error::Error>> {
let address = "https://www.zhihu.com/rss";
let mut parser = RssParser::from_url(address,"utf8").await?;
parser.author_tag = String::from("dc:creator");
assert!(parser.parse_json().await.is_ok());
Ok(())
}
RSS 转 Json
use future_rss::RssParser;
#[tokio::main]
async fn main()->Result<(),Box<dyn std::error::Error>> {
let address = "https://www.zhihu.com/rss";
let mut parser = RssParser::from_url(address,"utf8").await?;
parser.author_tag = String::from("dc:creator");
assert!(parser.parse_json().await.is_ok());
Ok(())
}
Rss 请求构建器
use future_rss::RssParser;
#[tokio::main]
async fn main()->Result<(),Box<dyn std::error::Error>> {
let address = "https://www.zhihu.com/rss";
let mut parser = RssParser::new();
parser.author_tag = "dc:creator".into();
parser.publish_tag = "pubDate".into();
let xml = parser.request_xml(address.as_str(),charset.as_str()).await?;
parser.set_xml(xml);
assert!(parser.parse_vec().await.is_ok());
Ok(())
}
高级
依赖项
~8–12MB
~244K SLoC