首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Rust和Gzipped文件

Rust和Gzipped文件
EN

Stack Overflow用户
提问于 2021-02-18 05:28:52
回答 1查看 298关注 0票数 0

我是Python和Golang开发人员,最近开始学习Rust。我当前的项目涉及处理数百个gzipped日志文件,每个文件包含数十万个JSON条目,每行一个JSON条目。我最初的尝试速度之慢令人惊讶。在研究这一点时,我注意到,即使在发布模式下编译,Python3的执行速度也要比Rust实现快得多。我做错了什么吗?

下面是我的Rust实现:

代码语言:javascript
复制
use std::io::{BufRead, BufReader};
use std::fs::File;
use libflate::gzip::Decoder;

fn main() {
    let path = "/path/to/input.json.gz";
    process_file(path);
}

fn process_file(path: &str) {
    let x = BufReader::new(Decoder::new(File::open(path).unwrap()).unwrap())
        .lines()
        .count();

    println!("Found {} events", x);
}

下面是做同样事情的快得多的Python代码:

代码语言:javascript
复制
import gzip

def main():
    path = "/path/to/input.json.gz";
    process_file(path)

def process_file(path):
    with gzip.open(path) as fp:
        count = 0
        for _ in fp:
            count += 1
    print(f"Found {count} events")

感谢您的阅读并走到了这一步。

EN

回答 1

Stack Overflow用户

发布于 2021-02-18 05:37:14

为了获得最佳性能,请尝试将flate2机箱与zlib-ng后端一起使用。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/66250215

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档