Eu gostaria de escrever uma função bash que imprima seções de texto entre linhas correspondentes ## mode: org
e ## # End of org
em um arquivo, com uma linha vazia entre as seções. Antes do ##
, pode haver qualquer número de espaços.
Aqui está um exemplo de arquivo do qual extrair informações.
file: test.sh
## mode: org
## * Using case statement
## # End of org
case $arg in
("V")
echo "Author"
;;
(*)
## mode: org
## ** Silent Error Reporting Mode (SERM) in getopts
## *** Detects warnings without printing built-in messages.
## *** Enabled by colon {:} as first character in shortopts.
## # End of org
break
;;
esac
A saída desejada seria
* Using case statement
** Silent Error Reporting Mode (SERM) in getopts
*** Detects warnings without printing built-in messages.
*** Enabled by colon {:} as first character in shortopts.
Eu fiz isso com
capture-org ()
{
sed -n '/^ *## mode: org$/,/^ *## # End of org$/s/ *//p' "$1" |
sed 's/^## mode: org$/\n## mode: org/' |
sed '/^## mode: org$/d' | sed '/^## # End of org$/d' | cut -c 3-
}
Isso pode ser feito de uma forma mais organizada?
Responder1
sed '/^[[:space:]]*## mode: org$/,/^[[:space:]]*## # End of org$/!d; /^[[:space:]]*## mode: org$/d; s/^[[:space:]]*## # End of org$//g; s/^[[:space:]]*## //'
Isso excluirá tudo que não estiver nos padrões inicial e final. Em seguida, ele removerá o padrão inicial e substituirá o padrão final por uma linha vazia (que se tornará o separador de bloco).