У меня есть данные, указанные ниже.
host_name Server1.domain.com
contacts DL - Desktop
contact_groups ravi, raj, rahim
host_name Server2.domain.com
contact_groups DL-Server
host_name Server3.domain.com
host_name Server4.domain.com
contacts Services,helpdesk,manager
Требуемые выходные данные приведены ниже.
host_name Server1.domain.com, contacts ravi,raj,rahim, Contact_group DL-Desktop
host_name Server2.domain.com contact_groups DL - Server
host_name Server3.domain.com
host_name Server4.domain.com contacts services,helpdesk,manager
решение1
Я уверен, что вы можете сделать это гораздо проще в awk, но awk меня не очень любит, поэтому вот мой взгляд на это с использованием всего, кроме кухонной раковины. Предполагая, что данные находятся в файле с именем file1
export output=; while read line; do if [[ "$line" =~ "host_name" ]]; then export output="${output}\n"; fi; export output="${output}, $line"; done < file1 && echo -e $output | sed 's/^, \?//' | sed '/^$/d'
Содержание файла1
host_name Server1.domain.com
contacts ravi, raj, rahim
contact_groups DL - Desktop
host_name Server2.domain.com
contact_groups DL-Server
host_name Server3.domain.com
host_name Server4.domain.com
contacts Services,helpdesk,manager
Вывод вышеуказанной команды
host_name Server1.domain.com, contacts ravi, raj, rahim, contact_groups DL - Desktop
host_name Server2.domain.com, contact_groups DL-Server
host_name Server3.domain.com
host_name Server4.domain.com, contacts Services,helpdesk,manager
решение2
$ sed -e '2,$ s/^host_name/\n&/' ravi.txt |
perl -n -e 'if (! m/^$/) {
chomp;
$line .= $_ . ", "
};
if (m/^$/ || eof) {
$line =~ s/ +/ /g; # merge multiple spaces into one space
$line =~ s/, $//; # strip the trailing comma
print $line,"\n" ;
$line=""
}'
host_name Server1.domain.com, contacts DL - Desktop, contact_groups ravi, raj, rahim
host_name Server2.domain.com, contact_groups DL-Server
host_name Server3.domain.com
host_name Server4.domain.com, contacts Services,helpdesk,manager
Сначала используйте sed
для преобразования ввода в абзацы (разделенные новой строкой). Затем perl
объедините строки в каждом абзаце и распечатайте их.
Это можно было бы сделать полностью на Perl, но я был ленив и решил, что проще преобразовать в абзацы, прежде чем перенести в простой скрипт Perl.