Eu tenho um arquivo de script que preciso modificar com outro script para inserir um texto na 8ª linha.
String para inserir:, Project_Name=sowstest
em um arquivo chamado start
.
Tentei usar awk e sed, mas meu comando está ficando distorcido.
sed -i '8i8 This is Line 8' FILE
insere na linha 8
8 This is Line 8
no arquivo FILE
-i
faz a modificação diretamente no arquivo FILE, sem saída para o stdout, conforme mencionado nos comentários de glenn jackman.
brew install gnu-sed
e , em seguida, use-o comgsed
sed '8i\ 8 This is Line 8' FILE
.Uma
ed
resposta.
em sua própria linha termina o modo de entrada;w
escreve;q
sai. O GNU ed tem umwq
comando para salvar e sair, mas os antigos não.Leitura adicional: https://gnu.org/software/ed/manual/ed_manual.html
fonte
OS X / macOS / FreeBSD
sed
A
-i
flag funciona de maneira diferente no macOSsed
e no GNUsed
.Aqui está a maneira de usá-lo no macOS / OS X:
Veja
man 1 sed
para mais informações.fonte
a resposta awk
fonte
#define SERVER@"http://10.35.42.54/ms0.8"
para uma linha específica. Como posso conseguir isso?>
é o símbolo de redirecionamento do shell, para que a saída do awk seja armazenada no arquivo chamado "file.new".O POSIX
sed
(e, por exemplo, OS Xsed
,sed
abaixo) precisai
ser seguido por uma barra invertida e uma nova linha. Além disso, pelo menos o OS Xsed
não inclui uma nova linha após o texto inserido:Para substituir uma linha, você pode usar os comandos
c
(alterar) ous
(substituir) por um endereço numérico:Alternativas usando
awk
:awk
interpreta barras invertidas em variáveis passadas com-v
mas não em variáveis passadas usandoENVIRON
:Ambos
ENVIRON
e-v
são definidos pelo POSIX.fonte
Soluções Perl:
rapido e sujo:
perl -lpe 'print "Project_Name=sowstest" if $. == 8' file
-l
retira as novas linhas e as adiciona novamente, eliminando a necessidade de "\ n"-p
loops sobre o arquivo de entrada, imprimindo todas as linhas-e
executa o código entre aspas simples$.
é o número da linhaequivalente à solução awk de @ glenn, usando argumentos nomeados:
perl -slpe 'print $s if $. == $n' -- -n=8 -s="Project_Name=sowstest" file
-s
permite um analisador de argumento rudimentar--
impede que -n e -s sejam analisados pelo analisador de argumentos perl padrãoargumentos de comando posicional:
perl -lpe 'BEGIN{$n=shift; $s=shift}; print $s if $. == $n' 8 "Project_Name=sowstest" file
variáveis ambientais:
ENV
é o hash que contém todas as variáveis de ambienteGetopt para analisar argumentos em hash% o:
perl -MGetopt::Std -lpe 'BEGIN{getopt("ns",\%o)}; print $o{s} if $. == $o{n}' -- -n 8 -s "Project_Name=sowstest" file
Getopt :: Nomes de opção longos e longos
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 é a solução de biblioteca padrão recomendada.
Isso pode ser um exagero para scripts perl de uma linha, mas pode ser feito
fonte
Para aqueles que estão no SunOS que não é GNU, o seguinte código ajudará:
fonte
sed -e '8iProject_Name=sowstest' -i start
usando GNU sedExemplo de execução:
fonte
$
na linha 3 após a inserção?-A
bandeira paracat
:)sed -i "" -e $ '4 a \\ n''Project_Name = sowstest' start
fonte