как я могу прокомментировать / в разделе в исходном коде с 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 

  • как использовать awk / cut для получения данных столбца, имеющего пространство
  • Как найти и заменить новую строку?
  • Как искать и заменять строку символами новой строки в командной строке в файле
  • Как извлечь определенные поля из строк с помощью команд оболочки?
  • команда sed для обмена символами
  • sed: -e выражение # 1, char 4: неизвестная команда:
  • Как присоединиться к двум csv с таким же количеством строк
  • Задача сравнения регулярных выражений / шаблонов для извлечения данных
  • 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 - лучшая ОС в мире.