将目录中所有*.txt文件合并为一个大文本文件的最快和最实用的方法是什么?

目前我正在使用cygwin的窗口,所以我可以访问BASH。

Windows shell命令也会很好,但我怀疑有没有一个。


当前回答

如果文件列表太长,点赞最多的答案将失败。

更可移植的解决方案是使用fd

fd -e txt -d 1 -X awk 1 > combined.txt

-d 1将搜索限制在当前目录。如果省略此选项,则它将递归地查找当前目录中的所有.txt文件。 -X(也称为——exec-batch)一次性为所有搜索结果执行命令(在本例中为awk 1)。

注意,fd不是一个“标准的”Unix程序,所以您可能需要安装它

其他回答

这种方法怎么样?

find . -type f -name '*.txt' -exec cat {} + >> output.txt

请记住,对于目前给出的所有解决方案,shell决定文件连接的顺序。巴什,IIRC,这是字母顺序。如果顺序很重要,您应该适当地命名这些文件(01file.txt, 02file.txt,等等),或者按照您想要连接的顺序指定每个文件。

$ cat file1 file2 file3 file4 file5 file6 > out.txt

这会将输出追加到all.txt

cat *.txt >> all.txt

这将覆盖all.txt

cat *.txt > all.txt

你可以这样做: 猫(directory_path) / * * / *。[h,m] > test.txt

如果使用{}包含要查找的文件的扩展名,则存在顺序问题。

要小心,因为这些方法都不能处理大量文件。就我个人而言,我用了这句话:

for i in $(ls | grep ".txt");do cat $i >> output.txt;done

编辑:就像有人在评论中说的,你可以用$(ls *.txt)替换$(ls | grep ".txt")

编辑:感谢@gnourf_gnourf的专业知识,使用glob是在目录中迭代文件的正确方法。因此,像$(ls | grep ".txt")这样亵渎神灵的表达式必须被*.txt取代(请参阅此处的文章)。

好的解决方案

for i in *.txt;do cat $i >> output.txt;done