spark 如何指定输出文件名

2016-04-13 17:17:00 +08:00
 zuo

hdfs 有一堆 gzip 文件, spark 读入后进行 map 做数据转换后,因为 gzip 文件不能分片,所以并行度是 1 。通过 RDD.saveAsTextFile(path)输出到 hdfs

遇到的问题: path 实际是输出的文件目录名,而真实的输出文件名为 part-00000.gz 。希望能得到输出文件名是 xxx.gz 而不是 part 前缀的文件名,大家有方法可以提供吗?最好有 Python 实现

6417 次点击
所在节点    程序员
2 条回复
MasterC
2016-04-13 23:15:27 +08:00
自定义 XXXOutPutFormat ,重写 getRecordWriter 方法,主要是在创建 DFSOutPutStream 的时候,手动指定输出文件名称,这样就可以实现自定义输出文件名了。我在 MR 里面是这么干的,应该也是可以引入到 spark 里面。
zuo
2016-04-15 10:12:24 +08:00
@MasterC 谢谢,昨天按照你的提示已经用 hadoop 重新实现了一遍

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/270786

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX