как я могу прокомментировать / в разделе в исходном коде с sed или awk

В настоящее время у меня есть файлы, содержащие такие разделы

code statement1 code statement2 # BEGIN SOMENAME some code some other code # END SOMENAME code statement n +1 code statement n +1 

Я хочу сделать это, чтобы прокомментировать, что находится между «# BEGIN SOMENAME» и «# END», так что в конце это выглядит так

 code statement1 code statement2 # BEGIN SOMENAME # some code # some other code # END SOMENAME code statement n +1 code statement n +1 

Могу ли я достичь этого с помощью awk или sed? и я могу легко его перевернуть ?, так что просто операция, которая снова «комментирует»?

Я хочу избежать ошибок, поэтому, если строки уже прокомментированы, их следует оставить в покое. Также в «комментарии в» он не должен пытаться что-то сделать, если строки между концом и началом не начинаются с «#».

Пробовал это сейчас несколько часов, никакого успеха.

Нашел возможный раствор:

 awk ' BEGIN { i=0; line_with_no_comment_found=0 } /^# END/ { m=0; if ( line_with_no_comment_found == 1 ) { for (var in a) print "# "a[var] } else { for (var in a) print a[var] } delete a; i=0; line_with_no_comment_found=0; } /^# / { if (m==0) { print } else { a[i++]=$0; } } !/^# / { if (m==0) { print } else { a[i++]=$0; line_with_no_comment_found=1} } /^# BEGIN ([a-zA-Z_])([1-9][0-9]*)*/ {m=1;} END { } '<<EOF 

  • Знаки sed «e» и «g» не работают вместе
  • используя цикл «for», непрерывно читает строку строки за строкой, рассматривая каждую строку как входной
  • Как удалить слова, заканчивающиеся буквой S, если дубликаты без S на конце находятся в одном списке?
  • Удалите новую строку \ linefeed перед повторением регулярного выражения
  • Удаление строк не более или меньше полей 'N'?
  • Как удалить строку символов после и до определенного символа?
  • Извлечение с помощью grep / sed первого шаблона, а затем второго шаблона, который имел некоторые строки до и связанные с первым
  • Как повторить строку для каждого значения соответствующего столбца
  • One Solution collect form web for “как я могу прокомментировать / в разделе в исходном коде с sed или awk”

    Этот скрипт работает для меня. Я тестировал его в GNU Awk 4.0.1, но должен работать и в Nawk.

     awk 'BEGIN { # action=0: uncomment # action=1: comment action=0 in_optional_code_block=0 } { if ($0 ~ /^# BEGIN/) { in_optional_code_block=1 } else if ($0 ~ /^# END/) { in_optional_code_block=0 } else if (in_optional_code_block) { if (action) { if ($0 !~ /^#/) { $0 = "# " $0 } } else { if ($0 ~ /^#/) { sub(/^# ?/, "") } } } } 1' 

    Я также написал небольшой сопроводительный сценарий оболочки:

     #!/usr/bin/env sh syntax_error() { echo "Usage: `basename \"$0\"` [comment|uncomment] file" >&2 exit 1 } case "$1" in 0|uncomment) action=0; ;; 1|comment) action=1; ;; *) syntax_error; ;; esac shift if [ -z "$@" ]; then syntax_error; fi awk 'BEGIN { action='$action' in_optional_code_block=0 } { if ($0 ~ /^# BEGIN/) { in_optional_code_block=1 } else if ($0 ~ /^# END/) { in_optional_code_block=0 } else if (in_optional_code_block) { if (action) { if ($0 !~ /^#/) { $0 = "# " $0 } } else { if ($0 ~ /^#/) { sub(/^# ?/, "") } } } } 1' "$@" > ".$@.commentswap" if [ $? -eq 0 ]; then mv ".$@.commentswap" "$@"; fi 

    (Если у вас есть GNU Awk 4.1.0 или новее, вы можете использовать флаг -i вместо конструкции перемещения в конце.)

    Linux и Unix - лучшая ОС в мире.