Meu arquivo,
ARCHIVE B1_NAME B2_NAME B3_NAME ELEMENT INFO_NAM WERT PROCID
-------- -------- -------- -------- -------- -------- ---- ------
15MinAvg AIRSS 33-GIS DMDMGIS1 I MvAvr15m 1123 CP
15MinAvg AIRSS 33-GIS DMDMGIS1 P MvAvr15m 2344 CP
15MinAvg AIRSS 33-GIS DMDMGIS1 Q MvAvr15m 4545 CP
15MinAvg AIRSS 33-GIS DMDMGIS2 I MvAvr15m 6576 CP
15MinAvg AIRSS 33-GIS DMDMGIS2 P MvAvr15m 4355 CP
15MinAvg AIRSS 33-GIS DMDMGIS2 Q MvAvr15m 6664 CP
Resultado,
ARCHIVE B1_NAME B2_NAME B3_NAME ELEMENT WERT
-------- -------- -------- -------- ------- ----
15MinAvg AIRSS 33-GIS DMDMGIS1 I 1123
15MinAvg AIRSS 33-GIS DMDMGIS1 P 2344
15MinAvg AIRSS 33-GIS DMDMGIS1 Q 4545
15MinAvg AIRSS 33-GIS DMDMGIS2 I 6576
15MinAvg AIRSS 33-GIS DMDMGIS2 P 4355
15MinAvg AIRSS 33-GIS DMDMGIS2 Q 6664
Eu quero excluir duas colunas INFO_NAM
e WERT
do meu arquivo de entrada.
shell
shell-script
text-processing
sed
awk
pmaipmui
fonte
fonte
INFO_NAM
ePROCID
excluídosawk '{$(NF-1)=$(NF-2)=""};1' <file | column -t
pode formatá-lo bem.Respostas:
Não imprima 6 ª e 8 ª coluna
fonte
Isso já foi respondido antes em outro lugar no Stack Overflow.
/programming/15361632/delete-a-column-with-awk-or-sed /programming/7551219/deleting-columns-from-a-file-with-awk -ou-a partir da linha de comando no linux etc.
Eu acredito que
awk
é o melhor para isso.É possível usar
cut
também.fonte
cut
ou não mencione isso?--complement
opção paracut
pode ser útil aqui, ou seja, a remoção de dois campos em vez de selecionar seis:cut -f6,8 --complement file
cut –c1-45,55-58
. Mas antes de executar isso, tenho que contar o total de caracteres, apenas eu posso isso. Mas eu queria imprimir as colunas com o mesmo que o meu formato de entradaUse
printf
para preservar o formato de cada campo. Cada campo tem x caracteres e o sinal de menos justifica a sequência restante.fonte