이 문서에 설명되어 man bash
있습니다. 공백이 아닌 IFS에서 문자의 단일 항목은 필드를 구분합니다.
보낸 사람 man bash
:
쉘은 IFS의 각 문자를 분리 문자로 취급하고이 확장 문자를 필드 종결 자로 사용하여 다른 확장 결과를 단어로 나눕니다. IFS가 설정되지 않은 경우, 또는 그 값이 정확히 경우 <space><tab><newline>
다음의 순서 기본 <space>
,
<tab>
및 <newline>
시작과 이전 확장의 결과의 끝에서 무시되고 IFS 문자의 순서가 아니라 시작 부분이나 끝 구분하는 역할을 말. IFS에 기본값 이외의 값이있는 경우 공백 문자가 IFS 값 (ISF 공백 문자)에있는 한 공백 문자 공백, 탭 및 개행 문자는 단어의 시작과 끝에서 무시됩니다. ). 인접한 IFS 공백 문자와 함께 IFS 공백이 아닌 IFS의 문자는 필드를 구분합니다. 일련의 IFS 공백 문자도 분리 문자로 처리됩니다. IFS 값이 널이면 단어 분할이 발생하지 않습니다. [공포도 추가]
예 : 필드 분할
IFS에 공백 문자가 없으면 공백이 필드에 포함됩니다.
$ ( IFS=',' x='one , two,three'; printf "<%s>\n" $x )
<one >
< two>
<three>
IFS에 공백과 쉼표가 모두 있으면 공백 순서와 쉼표, 공백 순서가 단일 구분 기호로 처리됩니다.
$ ( IFS=' ,' x='one , two,three'; printf "<%s>\n" $x )
<one>
<two>
<three>
쉼표 시퀀스는 빈 필드 시퀀스로 해석됩니다.
$ ( IFS=' ,' x='one,,,two,three'; printf "<%s>\n" $x )
<one>
<>
<>
<two>
<three>
예 : 선행 및 후행 공백
IFS에 공백이없는 경우 선행 및 후행 공백이 필드에 유지됩니다.
$ ( IFS=',' x=' one , two,three ,'; printf "<%s>\n" $x )
< one >
< two>
<three >
IFS에 공백이 있으면 선행 또는 후행 공백이 제거됩니다.
$ ( IFS=' ,' x=' one , two,three ,'; printf "<%s>\n" $x )
<one>
<two>
<three>