Вы можете использовать расширение параметра в 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.
Синтаксис этого регулярного выражения в 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
Синтаксис этого регулярного выражения в 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
Синтаксис этого регулярного выражения в 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
Эта команда sed вернет что-либо (.*) из начала строки (^) до и включит первое появление false, исключая остальные (.*$). [!d0 ]
sed -r 's/^(.*\<false\>).*$/\1/'
Эта команда sed вернет что-либо (.*) из начала строки (^) до и включит первое появление false, исключая остальные (.*$).
sed -r 's/^(.*\<false\>).*$/\1/'
Эта команда sed вернет что-либо (.*) из начала строки (^) до и включит первое появление false, исключая остальные (.*$).
sed -r 's/^(.*\<false\>).*$/\1/'