回答:
これにより、これら2つの文字列の内容が解析されます。
$ grep -o '".*"' somefile | sed 's/"//g'
arch
arch2
上記は、パターンに一致する文字列を探します".*"
。これは、二重引用符内で発生するすべてのものに一致します。したがって、grep
これらのタイプの値を返します。
"arch"
"arch2"
へのパイプsed
は、これらの文字列から二重引用符を取り除き、探している文字列を提供します。表記法sed 's/"//g'
はsed
、検索を実行し、二重引用符のすべての出現を置き換え、それらを何も置き換えないように指示していますs/"//g
。コマンドs/find/replace/g
はそこで行われていることであり、g
検索の末尾は、指定された文字列全体に対してグローバルに実行するよう指示しています。
またsed
、最初の二重引用符を切り捨て、それらの間にあるものを保持し、残りの引用符とその後のすべてを切り取るために使用することができます:
$ sed 's/^"\(.*\)".*/\1/' a
arch
arch2
$ grep -o '".*"' somefile | tr -d '"'
arch
arch2
このコマンドtr
を使用して、文字を削除できます。この場合、二重引用符が削除されます。
$ grep -oP '(?<=").*(?=")' somefile
arch
arch2
grep
のPCRE機能を使用すると、二重引用符で始まるか二重引用符で終わる部分文字列を検索して、部分文字列のみをレポートできます。
/address/
にsed
like を追加すると、sed '/^"\(arch[^"]*\)/s//\1/
その文字列を含む行のみを操作します。
sed
て、実際に実行する必要があることに気付きs/^"\([^"]*\)".*/\1/
ました。
それは別の仕事ですcut
:
VBoxManage list vms | cut -d \" -f2
cut
引用符を区切り文字として使用して各行をフィールドに分割し、フィールド2を出力します:フィールド1は最初の引用符の前の空の文字列、フィールド2は引用符の間の必要な文字列、フィールド3は残りの文字列ですライン。
sed
あなたが行うことができます。
var=$(VBoxManage list vms | sed 's/^"\([^"]*\).*/\1/')
説明:
s/.../.../
-一致して置換^
-行頭で一致\(...\)
-これは後方参照です。後でここで一致するものを参照できます \1
[^"]*
- "
(つまり、次まで"
)を含まないシーケンスに一致します.*
-残りの行と一致\1
-後方参照に置き換えますまたはawk
:
var=$(VBoxManage list vms | awk -F\" '{ print $2 }')
現代のシェルでは、通常の変数の代わりに配列を使用することもできます。ではbash
、あなたが行うことができます。
IFS=$'\n'; set -f
array=( $(VBoxManage list vms | awk -F\" '{ print $2 }') )
echo "array[0] = ${array[0]}"
echo "array[1] = ${array[1]}"
これは、変数を使用するようになると簡単になる場合があります。
bashを使用して、次のように記述します。
while read vm value; do
case $vm in
'"arch"') arch=$value ;;
'"arch2"') arch2=$value ;;
esac
done < <( VBoxManage list vms )
echo $arch
echo $arch2
tr -d \"
引用符を削除する別の方法です。(tr
通常、1つの文字セットを別の文字セットに変換-d
します。代わりにそれらを単に削除するように指示します。)