これは、すでに尋ねられた質問に似ています。しかし、私はSed固有の答えを探しています。次のようなテキストがあります。
いくつかのサンプルテキスト[いくつかの余分なテキストを含む].foo
角かっこ内のテキストだけを取得する必要があります。これまでの私の試みは無駄でした。他のツールで行を解析することはできますが、Sedに正しく解析させることができないようです。
このようなもの?
$ echo Some sample text [with some extra text].foo | sed -e 's/.*\[\([^]]*\)\].*/\1/g'
with some extra text
$ echo Some sample text [with some extra text].foo | sed -e 's/.*\[\([^]]*\)\].*/Your text was: "\1", okay?/g'
Your text was: "with some extra text", okay?
角かっこ内のテキストを置き換える例を次に示します。
$ echo 'Some sample text [with some extra text].foo' | sed -e 's/\[\(with some extra text\)\]/<\1>/g'
Some sample text <with some extra text>.foo
echo "Some [sample inside] text [with some extra text].foo" | sed -n '/\[/{ s/\]/\n/g; s/.[^\n]*\[/:/g;s/\..*//;p}'
:sample inside:with some extra text