Переименование списка символов в sed

Расширение параметра в bash

Вы можете использовать расширение параметра в bash, в этом случае

${parameter%word}, где word - /* ${parameter##word} где word - */

Примеры:

Удалить последнюю часть

$ asdf="xxx/xxxx/xxxxx/yyy"
$ echo ${asdf%/*}
xxx/xxxx/xxxxx

Это описано в man bash:

${parameter%word}
${parameter%%word}
      Remove matching suffix pattern.  The word is expanded to produce
      a pattern just as in pathname expansion.  If the pattern matches
      a  trailing portion of the expanded value of parameter, then the
      result of the expansion is the expanded value of parameter  with
      the  shortest  matching  pattern (the ``%'' case) or the longest
      matching pattern (the ``%%'' case) deleted.  If parameter  is  @
      or  *,  the  pattern  removal operation is applied to each posi‐
      tional parameter in turn, and the  expansion  is  the  resultant
      list.   If  parameter is an array variable subscripted with @ or
      *, the pattern removal operation is applied to  each  member  of
      the array in turn, and the expansion is the resultant list.

Удалить последнюю часть

$ asdf="xxx/xxxx/xxxxx/yyy"
$ echo ${asdf##*/}
yyy

Вы можете добавить косую черту, подобную

$ echo /${asdf##*/}
/yyy

, чтобы получить именно то, что вы хотели в одном конкретном случае в соответствии с отредактированным вопросом. Но после этого вопрос был отредактирован несколькими людьми, и теперь нелегко узнать, что вы хотите.

Это описано в man bash:

${parameter#word}
${parameter##word}
      Remove matching prefix pattern.  The word is expanded to produce
      a pattern just as in pathname expansion.  If the pattern matches
      the  beginning of the value of parameter, then the result of the
      expansion is the expanded value of parameter with  the  shortest
      matching  pattern  (the ``#'' case) or the longest matching pat‐
      tern (the ``##'' case) deleted.  If parameter is  @  or  *,  the
      pattern  removal operation is applied to each positional parame‐
      ter in turn, and the expansion is the resultant list.  If param‐
      eter  is  an array variable subscripted with @ or *, the pattern
      removal operation is applied to each  member  of  the  array  in
      turn, and the expansion is the resultant list.
0
задан 13 March 2018 в 16:19

6 ответов

Синтаксис этого регулярного выражения в sed идентичен. Например, если вы хотите заменить строку (строки), которая соответствует этому регулярному выражению, вы можете использовать команду substitute следующим образом (s/<old>/<new>/):

$ echo '11183 11183 1 0 0 0 0 false -- "-"' | sed 's/[0-9].* [a-z]* /_THE_NEW_STRING_/'
_THE_NEW_STRING_-- "-"

Конечно, вы можете использовать расширенные регулярные выражения -r, --regexp-extended, чтобы сделать вашу жизнь легкой в ​​некоторых случаях:

$ echo '11183 11183 1 0 0 0 0 false -- "-"' | sed -r 's/([0-9].* [a-z]* ).*/\1/'
11183 11183 1 0 0 0 0 false 

$ echo '11183 11183 1 0 0 0 0 false -- "-"' | sed -r 's/([0-9].* [a-z]* )(.*)/\2 \1/'
-- "-" 11183 11183 1 0 0 0 0 false 
1
ответ дан 22 May 2018 в 12:36
  • 1
    Не работает: $ echo '11183 11183 1 0 0 0 0 false 00000 999 xxx test 1-#+X abc -- "-" test' | sed -r 's/([0-9].* [a-z]* ).*/\1/' - & gt; [F2] – RoVo 13 March 2018 в 16:40
  • 2
    @RoVo, я согласен с вашим беспокойством о регулярном выражении, но IMO вопрос не об этом. – pa4080 13 March 2018 в 17:00

Синтаксис этого регулярного выражения в sed идентичен. Например, если вы хотите заменить строку (строки), которая соответствует этому регулярному выражению, вы можете использовать команду substitute следующим образом (s/<old>/<new>/):

$ echo '11183 11183 1 0 0 0 0 false -- "-"' | sed 's/[0-9].* [a-z]* /_THE_NEW_STRING_/' _THE_NEW_STRING_-- "-"

Конечно, вы можете использовать расширенные регулярные выражения -r, --regexp-extended, чтобы сделать вашу жизнь легкой в ​​некоторых случаях:

$ echo '11183 11183 1 0 0 0 0 false -- "-"' | sed -r 's/([0-9].* [a-z]* ).*/\1/' 11183 11183 1 0 0 0 0 false $ echo '11183 11183 1 0 0 0 0 false -- "-"' | sed -r 's/([0-9].* [a-z]* )(.*)/\2 \1/' -- "-" 11183 11183 1 0 0 0 0 false
1
ответ дан 17 July 2018 в 18:56

Синтаксис этого регулярного выражения в sed идентичен. Например, если вы хотите заменить строку (строки), которая соответствует этому регулярному выражению, вы можете использовать команду substitute следующим образом (s/<old>/<new>/):

$ echo '11183 11183 1 0 0 0 0 false -- "-"' | sed 's/[0-9].* [a-z]* /_THE_NEW_STRING_/' _THE_NEW_STRING_-- "-"

Конечно, вы можете использовать расширенные регулярные выражения -r, --regexp-extended, чтобы сделать вашу жизнь легкой в ​​некоторых случаях:

$ echo '11183 11183 1 0 0 0 0 false -- "-"' | sed -r 's/([0-9].* [a-z]* ).*/\1/' 11183 11183 1 0 0 0 0 false $ echo '11183 11183 1 0 0 0 0 false -- "-"' | sed -r 's/([0-9].* [a-z]* )(.*)/\2 \1/' -- "-" 11183 11183 1 0 0 0 0 false
1
ответ дан 23 July 2018 в 19:44

Эта команда sed вернет что-либо (.*) из начала строки (^) до и включит первое появление false, исключая остальные (.*$). [!d0 ]

sed -r 's/^(.*\<false\>).*$/\1/'
2
ответ дан 22 May 2018 в 12:36
  • 1
    почему пустая группа захвата? – Zanna 13 March 2018 в 16:45
  • 2
    Я пытаюсь сопоставить false, но не notfalse или falsetto. Это может быть ( false ), но я не хочу повторять последнее пространство. – RoVo 13 March 2018 в 16:48
  • 3
    Ah :) GNU sed поддерживает границы слов, поэтому вы можете использовать \<false\> (работает, если до начала строки или после окончания строки). Но пример OP этого не требует. Я думаю, этот вопрос бессмысленен, потому что нет возможности рассказать о том, что уникально или передается по их требованию – Zanna 13 March 2018 в 16:54
  • 4
    поэтому я иногда все еще отвечаю на бессмысленные вопросы ;-) ... практикую и изучаю новые вещи. благодаря! – RoVo 13 March 2018 в 16:57
  • 5
    @ pa4080, может быть, вы хотите отрицания? Как sed -r 's/([^[a-z]]* [a-z]*) .*/\1/' Извините, я не могу ответить абстрактно. (Не соглашайтесь с тем, что sed не является правильным инструментом - любая относительно простая обработка текста может быть выполнена с помощью sed) – Zanna 13 March 2018 в 17:58

Эта команда sed вернет что-либо (.*) из начала строки (^) до и включит первое появление false, исключая остальные (.*$).

sed -r 's/^(.*\<false\>).*$/\1/'
2
ответ дан 17 July 2018 в 18:56

Эта команда sed вернет что-либо (.*) из начала строки (^) до и включит первое появление false, исключая остальные (.*$).

sed -r 's/^(.*\<false\>).*$/\1/'
2
ответ дан 23 July 2018 в 19:44
  • 1
    почему пустая группа захвата? – Zanna 13 March 2018 в 16:45
  • 2
    Я пытаюсь сопоставить false, но не notfalse или falsetto. Это может быть ( false ), но я не хочу повторять последнее пространство. – RoVo 13 March 2018 в 16:48
  • 3
    Ah :) GNU sed поддерживает границы слов, поэтому вы можете использовать \<false\> (работает, если до начала строки или после окончания строки). Но пример OP этого не требует. Я думаю, этот вопрос бессмысленен, потому что нет возможности рассказать о том, что уникально или передается по их требованию – Zanna 13 March 2018 в 16:54
  • 4
    поэтому я иногда все еще отвечаю на бессмысленные вопросы ;-) ... практикую и изучаю новые вещи. благодаря! – RoVo 13 March 2018 в 16:57
  • 5
    @ pa4080, может быть, вы хотите отрицания? Как sed -r 's/([^[a-z]]* [a-z]*) .*/\1/' Извините, я не могу ответить абстрактно. (Не соглашайтесь с тем, что sed не является правильным инструментом - любая относительно простая обработка текста может быть выполнена с помощью sed) – Zanna 13 March 2018 в 17:58

Другие вопросы по тегам:

Похожие вопросы: