Відповіді:
sed -i '8i8 This is Line 8' FILE
вставки по лінії 8
8 This is Line 8
у файл FILE
-i
робить модифікацію безпосередньо для файлу FILE, виводу до stdout немає, як згадується у коментарях glenn jackman.
brew install gnu-sed
а потім скористайтеся цимgsed
sed '8i\ 8 This is Line 8' FILE
.
ed
відповідь
ed file << END
8i
Project_Name=sowstest
.
w
q
END
.
у власному рядку закінчується режим введення; w
пише; q
кидає. У GNU ed є wq
команда зберігати та виходити, але стара редакція цього не робить.
Подальше читання: https://gnu.org/software/ed/manual/ed_manual.html
sed
-i
Прапор працює по- різному на MacOS , sed
ніж в GNU sed
.
Ось спосіб використовувати його в macOS / OS X:
sed -i '' '8i\
8 This is Line 8' FILE
Див. Для man 1 sed
отримання додаткової інформації.
відповідь awk
awk -v n=8 -v s="Project_Name=sowstest" 'NR == n {print s} {print}' file > file.new
#define SERVER@"http://10.35.42.54/ms0.8"
до певного рядка. Як я можу цього досягти?
>
є символом перенаправлення оболонки, щоб висновок awk зберігався у файлі під назвою "file.new".
POSIX sed
(і, наприклад, OS X sed
, sed
нижче), i
повинен супроводжуватися зворотним нахилом та новою лінією. Також принаймні ОС 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
(зміни) або s
(замінити) з числовою адресою:
$ 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.
Рішення Perl:
perl -lpe 'print "Project_Name=sowstest" if $. == 8' file
-l
знімає нові рядки та додає їх назад, усуваючи необхідність "\ n"-p
петлі над вхідним файлом, друкуючи кожен рядок-e
виконує код в одиничних лапках$.
номер рядка
perl -slpe 'print $s if $. == $n' -- -n=8 -s="Project_Name=sowstest" file
-s
вмикає аналізатор рудиментарних аргументів--
запобігає розбору -n і -s стандартним аналізатором аргументів perlperl -lpe 'BEGIN{$n=shift; $s=shift}; print $s if $. == $n' 8 "Project_Name=sowstest" file
setenv n 8 ; setenv s "Project_Name=sowstest"
echo $n ; echo $s
perl -slpe 'print $ENV{s} if $. == $ENV{n}' file
ENV
це хеш, який містить усі змінні середовища
perl -MGetopt::Std -lpe 'BEGIN{getopt("ns",\%o)}; print $o{s} if $. == $o{n}' -- -n 8 -s "Project_Name=sowstest" file
perl -MGetopt::Long -lpe 'BEGIN{GetOptions(\%o,"line=i","string=s")}; print $o{string} if $. == $o{line}' -- --line 8 --string "Project_Name=sowstest" file
Getopt - рекомендоване стандартне бібліотечне рішення.
Це може бути зайвим для однорядних сценаріїв perl, але це можна зробити
Для тих, хто перебуває на SunOS, який не є GNU, допоможе наступний код:
sed '1i\^J
line to add' test.dat > tmp.dat
sed -e '8iProject_Name=sowstest' -i start
з використанням GNU sed
Проба зразка:
[root@node23 ~]# for ((i=1; i<=10; i++)); do echo "Line #$i"; done > a_file
[root@node23 ~]# cat a_file
Line #1
Line #2
Line #3
Line #4
Line #5
Line #6
Line #7
Line #8
Line #9
Line #10
[root@node23 ~]# sed -e '3ixxx inserted line xxx' -i a_file
[root@node23 ~]# cat -An a_file
1 Line #1$
2 Line #2$
3 xxx inserted line xxx$
4 Line #3$
5 Line #4$
6 Line #5$
7 Line #6$
8 Line #7$
9 Line #8$
10 Line #9$
11 Line #10$
[root@node23 ~]#
[root@node23 ~]# sed -e '5ixxx (inserted) "line" xxx' -i a_file
[root@node23 ~]# cat -n a_file
1 Line #1
2 Line #2
3 xxx inserted line xxx
4 Line #3
5 xxx (inserted) "line" xxx
6 Line #4
7 Line #5
8 Line #6
9 Line #7
10 Line #8
11 Line #9
12 Line #10
[root@node23 ~]#
$
лінія з лінії 3 після вставки?
-A
прапора до cat
:)
sed -i "" -e $ '4 a \\ n''Project_Name = sowstest' start