我试图找出是否可以在单个sed命令中编辑一个文件,而无需手动将编辑的内容流到一个新文件中,然后将新文件重命名为原始文件名。
我尝试了-i选项,但是Solaris系统说-i是非法选项。还有别的办法吗?
我试图找出是否可以在单个sed命令中编辑一个文件,而无需手动将编辑的内容流到一个新文件中,然后将新文件重命名为原始文件名。
我尝试了-i选项,但是Solaris系统说-i是非法选项。还有别的办法吗?
当前回答
非常好的例子。我在编辑许多文件时遇到了挑战,而-i选项似乎是在find命令中使用它的唯一合理解决方案。下面的脚本在每个文件的第一行前面添加“version:”:
find . -name pkg.json -print -exec sed -i '.bak' '1 s/^/version /' {} \;
其他回答
支持-i选项就地编辑文件的sed版本写入临时文件,然后重命名该文件。
或者,你可以只使用ed。例如,要更改文件file.txt中所有出现的foo为bar,你可以这样做:
echo ',s/foo/bar/g; w' | tr \; '\012' | ed -s file.txt
语法类似于sed,但肯定不完全相同。
即使没有-i支持sed,也可以很容易地编写一个脚本来完成这项工作。而不是sed -i 's/foo/bar/g'文件,你可以做内联文件sed 's/foo/bar/g'。这样的脚本编写起来很简单。例如:
#!/bin/sh
IN=$1
shift
trap 'rm -f "$tmp"' 0
tmp=$( mktemp )
<"$IN" "$@" >"$tmp" && cat "$tmp" > "$IN" # preserve hard links
对于大多数用途应该是足够的。
如果你想替换包含'/'的sting,你可以使用'?'。例如,将所有*.py文件的“/usr/local/bin/python”替换为“/usr/bin/python3”。
找到。/usr/bin/python ?/usr/bin/python3?G ' {} \;
mv file.txt file.tmp && sed 's/foo/bar/g' < file.tmp > file.txt
应该保留所有硬链接,因为输出被直接返回以覆盖原始文件的内容,并且避免了对sed的任何特殊版本的需要。
非常好的例子。我在编辑许多文件时遇到了挑战,而-i选项似乎是在find命令中使用它的唯一合理解决方案。下面的脚本在每个文件的第一行前面添加“version:”:
find . -name pkg.json -print -exec sed -i '.bak' '1 s/^/version /' {} \;
Sed支持就地编辑。来自男人sed:
-i[SUFFIX], --in-place[=SUFFIX]
edit files in place (makes backup if extension supplied)
例子:
假设你有一个文件hello。图文短信:
hello world!
如果你想保留旧文件的备份,使用:
sed -i.bak 's/hello/bonjour' hello.txt
你会得到两个文件:hello.txt,内容如下:
bonjour world!
还有hello。txt。bak的旧内容。
如果不想保留副本,只需不要传递扩展参数。