当我们使用sort file命令时, 该文件以排序的方式显示其内容。如果我不想在stdout上获得任何输出,而是在输入文件中获得输出,该怎么办?


当前回答

要对文件夹和覆盖它们的子文件夹中的所有文件进行排序吗?

用这个:

find . -type f -exec sort {} -o {} \;

其他回答

没有几个文件的答案,所以:

sort -u file1 file2 -o file1

下面是(ab)使用vim的方法:

vim -c :sort -c :wq -E -s "${filename}"

-c:sort -c:wq部分在文件打开后调用命令进行vim。-E和-s是必要的,这样vim以“无头”模式执行,不会绘制到终端。

与sort -o "${filename}" "${filename}"方法相比,这几乎没有任何好处,除了它只接受filename参数一次。


这对我在.gitignore文件的nanorc条目中实现格式化器指令很有用。以下是我使用的方法:

syntax "gitignore" "\.gitignore$"

formatter vim -c :sort -c :wq -E -s

要对文件进行排序,请尝试:

echo "$(sort your_file)" > your_file

正如在其他回答中解释的那样,您不能直接将输出重定向到输入文件。但是您可以先计算排序命令,然后将其重定向到原始文件。通过这种方式,您可以实现就地排序。

类似地,您还可以将此技巧应用于其他命令,如paste,以实现逐行追加。

sort file | sponge file

它包含在以下Fedora包中:

moreutils : Additional unix utilities
Repo        : fedora
Matched from:
Filename    : /usr/bin/sponge

你可以使用sort的-o,——output=FILE选项来指示相同的输入和输出文件:

sort -o file file

不重复文件名(使用bash大括号展开)

sort -o file{,}

⚠️重要提示:一个常见的错误是试图将输出重定向到相同的输入文件 (例如排序文件>文件)。这不起作用,因为shell正在使重定向(而不是sort(1)程序)和输入文件(作为输出)将被擦除,然后才给sort(1)程序读取它的机会。