我有数以万计的 gzip 压缩文本文件,每个文件都已经在内部进行了排序。
我编写了一个脚本来解压缩它们(创建一个副本),然后使用sort -m
它们来合并它们。
这一切都运行良好,但在尝试提高性能时,我注意到解压缩操作约占总运行时间的 16-20%。
基本上,合并操作必须重复扫描整个文本文件,一次将 16 个文件合并为 1 个。通常,这会导致对我拥有的数据进行大约 4-5 次完整扫描。解压缩基本上增加了一次额外的扫描。
通过 50-100 GB 的数据节省 5-6 次扫描中的 1 次是一项可观的节省。
因此,我开始想知道是否可以将输出gunzip
直接输入sort
(或其他工具)并基本上将解压缩轮与第一轮合并相结合。输出不会被压缩。
有谁知道这是否可以做到?理想情况下使用标准工具,但如果符合要求,我也愿意接受第三方工具。
您可以 - 程序zcat
(或gzip -cd
)将解压缩的数据写入标准输出。从那里,您可以使用 bash 的进程替换。1.gz
是数字 1 到 3;a.gz
是字母 a 到 c;和z.gz
是4号和字母d:
$ sort -m <(zcat 1.gz) <(zcat a.gz) <(zcat z.gz)
1
2
3
4
a
b
c
d
Run Code Online (Sandbox Code Playgroud)
希望你的数据更有趣一些。