当我们使用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)程序读取它的机会。