Exibe a saída do grep nas colunas da tabela

0

Eu preciso mostrar a saída do grep nas colunas da tabela.

Eu tenho um script que pega informações do whois para exibir a criação, a data de expiração e o servidor ns de nomes de domínio específicos.

#!/bin/sh
cat domain-file.txt  | while read line ; do
lLine="$(echo $line | tr '[A-Z]' '[a-z]')"
echo "$lLine\t" >> table.csv;
sleep 3
echo "\n$lLine"
host=whois.nic.re
created=$(whois -h $host $lLine | egrep -i 'created:')
echo "$created\t" >> table.csv
sleep 2
expire=$(whois -h $host $lLine | egrep -i 'Expiry Date:')
echo "$expire\t" >> table.csv
sleep 2
nserver=$(whois -h $host $lLine | egrep -i 'nserver:')
echo "$nserver\t" >> table.csv
echo "------------------------------------------" >> table.csv
done
exit

Tudo está funcionando bem, exceto que estou tentando exibir a saída em uma tabela como esta:

Domain          Created Date    Expiry date     NS
abcd.com        19/01/2018      19/01/2019      ns.abcd.com ns2.abcd.com
1234.com        19/01/2018      19/01/2019      ns.1234.com ns2.1234.com        

Em vez disso, estou obtendo uma saída assim:

abcd.com        
Created date: 19/01/2018        
Expiry date: 19/01/2019         
nserver: ns.abcd.com 
nserver: ns2.abcd.com
------------------------------------------
1234.com        
Created date: 19/01/2018        
Expiry date: 19/01/2019         
nserver: ns.1234.com 
nserver: ns2.1234.com
    
por Marcus 15.05.2018 / 05:37

2 respostas

1

Eu sempre uso vírgula como um delimitador para arquivos CSV para uma melhor visualização em opencalc ou excel. Tente o seguinte código que eu não testei.

#!/bin/sh
echo -e "Domain,Created Date,Expiry_date,NS" > table.csv
cat domain-file.txt  | while read line ; 
do
    lLine="$(echo $line | tr '[A-Z]' '[a-z]')"
    host=whois.nic.re
    created=$(whois -h $host $lLine | egrep -i 'created:' | awk -F ':' '{print $NF}')
    expire=$(whois -h $host $lLine | egrep -i 'Expiry Date:' | awk -F ':' '{print $NF}')
    nserver=$(whois -h $host $lLine | egrep -i 'nserver:' | awk -F ':' '{print $NF}')
    echo -e "$lLine,$created,$expire,$nserver" >> table.csv
done
exit

Para ver o resultado no terminal:

 column -t -s',' table.csv
    
por 15.05.2018 / 06:59
1

Como você está dizendo, é possível salvar informações em csv com o delimitador TAB , ou seja, \t , e a meta de fazer esse problema é imprimir os dados nas colunas

Apenas tente isso e funcionará

column  -t -s$'\t' -n table.csv
    
por 15.05.2018 / 08:42