我有一个脚本文件,我需要用另一个脚本修改,在第8行插入一个文本。
要插入的字符串:Project_Name=sowstest,到一个名为start的文件中。
我尝试使用awk和sed,但我的命令变得混乱。
我有一个脚本文件,我需要用另一个脚本修改,在第8行插入一个文本。
要插入的字符串:Project_Name=sowstest,到一个名为start的文件中。
我尝试使用awk和sed,但我的命令变得混乱。
当前回答
谢谢umläute
sed -i "" -e $'4 a\\\n''Project_Name=sowstest' filename
下面的代码在macOS上很有用,可以在4之后添加新行
为了循环我创建了一个文件夹数组,在mac zsh中迭代它们
for foldercc in $foldernames;
sed -i "" -e $'4 a\\\n''Project_Name=sowstest' $foldercc/filenames;
其他回答
一个成功的答案
ed file << END
8i
Project_Name=sowstest
.
w
q
END
. 在它自己的行结束输入模式;w写道;q退出。GNU ed有一个wq命令来保存和退出,但旧ed没有。
进一步阅读:https://gnu.org/software/ed/manual/ed_manual.html
sed -i "" -e $'4 a\\\n''Project_Name=sowstest' start
这一行在macOS中工作正常
POSIX sed(例如OS X的sed,下面的sed)要求i后面跟着一个反斜杠和换行符。而且至少OS X的sed没有在插入的文本后包含换行符:
$ seq 3|gsed '2i1.5'
1
1.5
2
3
$ seq 3|sed '2i1.5'
sed: 1: "2i1.5": command i expects \ followed by text
$ seq 3|sed $'2i\\\n1.5'
1
1.52
3
$ seq 3|sed $'2i\\\n1.5\n'
1
1.5
2
3
要替换一行,你可以使用带有数字地址的c (change)或s (substitute)命令:
$ seq 3|sed $'2c\\\n1.5\n'
1
1.5
3
$ seq 3|gsed '2c1.5'
1
1.5
3
$ seq 3|sed '2s/.*/1.5/'
1
1.5
3
使用awk的替代方案:
$ seq 3|awk 'NR==2{print 1.5}1'
1
1.5
2
3
$ seq 3|awk '{print NR==2?1.5:$0}'
1
1.5
3
awk解释使用-v传递的变量中的反斜杠,但不解释使用ENVIRON传递的变量中的反斜杠:
$ seq 3|awk -v v='a\ba' '{print NR==2?v:$0}'
1
a
3
$ seq 3|v='a\ba' awk '{print NR==2?ENVIRON["v"]:$0}'
1
a\ba
3
ENVIRON和-v都由POSIX定义。
谢谢umläute
sed -i "" -e $'4 a\\\n''Project_Name=sowstest' filename
下面的代码在macOS上很有用,可以在4之后添加新行
为了循环我创建了一个文件夹数组,在mac zsh中迭代它们
for foldercc in $foldernames;
sed -i "" -e $'4 a\\\n''Project_Name=sowstest' $foldercc/filenames;
在Linux中添加2行可以很好地工作。
sed '2s/$/ myalias/' file