Bashシェルスクリプトの最初にあるのは次の行です。
IFS=$'\n'
このシンボルのコレクションの背後にある意味は何ですか?
IFS
は「内部フィールドセパレーター」を表します。シェルでは、Wordの分割方法を決定するために使用されます。 e。単語の境界を認識する方法。
Bashのようなシェルでこれを試してください(他のシェルはこれを異なる方法で処理する可能性があります。たとえば、zsh)。
mystring="foo:bar baz rab"
for Word in $mystring; do
echo "Word: $Word"
done
IFS
のデフォルト値は、空白文字(正確には、スペース、タブ、改行)で構成されます。各文字はWord境界にすることができます。したがって、デフォルト値のIFS
を使用すると、上記のループが出力されます。
Word: foo:bar
Word: baz
Word: rab
言い換えれば、シェルは空白はWordの境界であると考えています。
ここで、ループを実行する前にIFS=:
を設定してみてください。今回の結果は次のとおりです。
Word: foo
Word: bar baz rab
現在、シェルはmystring
も単語に分割しますが、現在はコロンのみを単語の境界として扱います。
IFS
の最初の文字は特殊です:特殊な$*
変数を使用する場合、出力内の単語を区切るために使用されます( Advanced Bash Scripting Guide からの例)、ここでそのような特殊変数に関する詳細情報も見つけることができます):
$ bash -c 'set w x y z; IFS=":-;"; echo "$*"'
w:x:y:z
と比較:
$ bash -c 'set w x y z; IFS="-:;"; echo "$*"'
w-x-y-z
どちらの例でも、シェルはすべての文字:
、-
、;
をWordの境界として扱います。変更されるのは、$*
の動作だけです。
もう1つ知っておくべき重要なことは、いわゆる「IFS空白」 処理される です。基本的に、IFS
に空白文字が含まれるとすぐに、先頭と末尾の空白は、処理する前に分割する文字列から削除され、sequence連続する空白文字でフィールドを区切ります。ただし、これは実際にIFS
に存在する空白文字にのみ適用されます。
たとえば、文字列"a:b:: c d "
(末尾のスペースとc
とd
の間の2つのスペース文字)を見てみましょう。
IFS=:
を使用すると、"a"
、"b"
、""
(空の文字列)と" c d "
(再び、c
およびd
)。最後のフィールドの先頭と末尾の空白に注意してください。IFS=' :'
を使用すると、"a"
、"b"
、""
(空の文字列)、"c"
および"d"
の5つのフィールドに分割されます。前後の空白はどこにもありません。2番目の例では、複数の連続する空白文字が2つのフィールドを区切るのに対して、複数の連続するコロンは区切りません(空白文字ではないため)。
IFS=$'\n'
については、bash
、zsh
、mksh
およびFreeBSD sh
でもサポートされるksh93
構文です(すべてのシェル間のバリエーション)。 bashマンページの引用:
$ 'string'形式の単語は特別に扱われます。 Wordは "string"に展開され、バックスラッシュでエスケープされた文字はANSI C標準で指定されているとおりに置き換えられます。
\n
は改行のエスケープシーケンスなので、IFS
は単一の改行文字に設定されます。
ドル記号の付いた一重引用符内では、一部の文字が特別に評価されます。例えば、 \n
は新しい行に変換されます。
したがって、この特定の行は、変数IFSに改行を割り当てます。次に、IFSはbashの特別な変数である内部フィールドセパレータです。なので man bash
言う、それ
展開後のWord分割と、
read
組み込みコマンドで行を単語に分割するために使用されます。デフォルト値は<space><tab><newline>
。
略して、IFS=$'\n'
は改行\n
を変数IFS
に割り当てます。
$'string'
構文は、エスケープシーケンスのようにANSI Cをデコードするために使用する引用メカニズムです。この構文はksh93
に由来し、bash
、zsh
、pdksh
、busybox sh
などの最新のシェルに移植できました。
この構文はPOSIXでは定義されていませんが、 SUS issue 7 で受け入れられています。