Imprimindo texto entre tags organizacionais

Imprimindo texto entre tags organizacionais

Eu gostaria de escrever uma função bash que imprima seções de texto entre linhas correspondentes ## mode: orge ## # End of orgem 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).

informação relacionada