Remover os caracteres de fim de linha do stdout? Várias linhas em uma única linha

11

Eu tenho um script que gera o seguinte texto. Esta é a saída de um Modem Netopia 2210-02 ADSL2 .

ADSL Line State:        Up
ADSL Startup Attempts:  1
ADSL Modulation:        DMT
ADSL Data Path:         Fast
Datapump Version:       DSP 7.2.3.0, HAL 7.2.1.0
SNR Margin:                   8.20        9.00 dB
Line Attenuation:            57.50       31.00 dB
Output Power:                17.09       12.34 dBm
Errored Seconds:                 0           0
Loss of Signal:                  0         476
Loss of Frame:                   0           0
CRC Errors:                  57921         416
Data Rate:                    2880        1024

Como posso remover o caractere de fim de linha de cada linha? Eu gostaria que a saída parecesse algo assim (Sim, é feia):

ADSL Line State:        Up ADSL Startup Attempts:  1 ADSL Modulation:        DMT ADSL Data Path:         Fast Datapump Version:       DSP 7.2.3.0, HAL 7.2.1.0 SNR Margin:                   8.20        9.00 dB Line Attenuation:            57.50       31.00 dB Output Power:                17.09       12.34 dBm Errored Seconds:                 0           0 Loss of Signal:                  0         476 Loss of Frame:                   0           0 CRC Errors:                  57921         416 Data Rate:                    2880        1024 

Eu tentei algumas soluções como essa, mas elas não funcionam:

# (This simply outputs the contents of the script, unmodified)
stefanl@hosta:~/Work/Cacti $ ./script | sed -e 's/$//'

Eu também tentei usar tr . Eu estava esperando o seguinte comando para substituir cada caractere de nova linha com o caractere de espaço. Isso levaria as várias linhas e as combinaria em uma única linha longa. Em vez disso, isso exibe apenas a última linha de saída. Parece sobrescrever cada linha subseqüente com a próxima linha de saída.

stefanl@hosta:~/Work/Cacti $ ./script | tr '\n' ' '
Data Rate:                    2880        1024stefanl@hosta:~/Work/Cacti $
stefanl@hosta:~/Work/Cacti $

Atualizar :

Após um exame mais aprofundado, parece que cada linha é precedida por um caractere de retorno. Isso aparece como ^M ao usar less . Então, eu adicionei duas declarações tr . Um para excluir caracteres de nova linha, um para excluir o caractere de retorno.

./script | | tr -d '\n' | tr -d '\r'
    
por Stefan Lasiewski 20.10.2010 / 06:08

4 respostas

15

sed não funciona (facilmente) porque opera em linhas uma por vez; você poderia fazer isso, mas envolveria copiar toda a entrada no buffer de espera

tr deve funcionar da maneira como você colou; Você tem certeza de que as novas linhas são \n s? Você pode simplificá-lo um pouco excluindo as novas linhas em vez de convertê-las em espaços:

tr -d '\n'
    
por 20.10.2010 / 06:34
5

além de tr , alguns outros métodos que você pode usar

awk

awk '1' ORS= file

shell

while read -r line; do printf "%s " "$line"; done <file

sed

sed -e ':a' -e 'N;s/\n/ /;ba' file
    
por 24.10.2010 / 06:38
0

Use tr -s '\n' para substituir seqüências de caracteres de nova linha repetidos por uma única ocorrência de nova linha.

Exemplo:

>>> echo -e "Squeeze\n\n\nthose\n\n\n\nnewlines\n"
Squeeze


those



newlines

2z [franck:~] $ 
>>> echo -e "Squeeze\n\n\nthose\n\n\n\nnewlines\n" | tr -s '\n'
Squeeze
those
newlines

(veja man tr )

    
por 29.10.2017 / 18:16
0

Para remover caracteres de nova linha, é tr -d '\n' < file . No entanto, para unir todas as linhas, isso é paste -sd 'tr -d '\n'' file .

awk produz saída sem texto, pois não termina a linha com um caractere de nova linha.

Para remover todos os caracteres CR, você pode fazer:

tr -d '\r' < file | paste -sd '
CR=$(printf '\r')
sed "s/$CR\$//" < file | paste -sd '
awk '{gsub(/\r$/, ""); printf "%s", $0} 
     END {if (NR) print ""}' < file
' -
' -

Para remover apenas os caracteres CR que estão no final das linhas:

 dos2unix < file | paste -sd '
tr -d '\r' < file | paste -sd '
CR=$(printf '\r')
sed "s/$CR\$//" < file | paste -sd '
awk '{gsub(/\r$/, ""); printf "%s", $0} 
     END {if (NR) print ""}' < file
' -
' -
' -

Ou use dos2unix para tudo:

 dos2unix < file | paste -sd '%pre%' -

Ou use %code% (o que removeria os CRs à direita e também corrigiria alguns outros problemas com arquivos de texto do Microsoft OSes):

%pre%     
por 29.10.2017 / 21:08