답변:
할당은 개행 문자를 제거 하지 않고 실제로 echo
수행합니다. 줄 바꿈을 유지하려면 문자열을 따옴표로 묶어야합니다.
echo "$testvar"
이것은 당신이 원하는 결과를 줄 것입니다. 데모는 다음 내용을 참조하십시오.
pax> cat num1.txt ; x=$(cat num1.txt)
line 1
line 2
pax> echo $x ; echo '===' ; echo "$x"
line 1 line 2
===
line 1
line 2
이유 줄 바꿈은 공백으로 대체 이유가없는 완전히 와 함께 할 echo
오히려 사물의 조합이다, 명령.
명령 줄이 주어지면 변수 bash
에 대한 문서에 따라 단어로 분할합니다 IFS
.
IFS : 확장 후 단어 분할에 사용되는 내부 필드 구분 기호입니다
<space><tab><newline>
. 기본값은 .
기본적으로이 세 문자 중 하나를 사용하여 명령을 개별 단어로 분할 할 수 있습니다. 그 후에 단어 구분 기호가 사라지고 남은 것은 단어 목록뿐입니다.
이를 echo
문서 ( bash
내부 명령) 와 결합 하면 공백이 출력되는 이유를 알 수 있습니다.
echo [-neE] [arg ...] : 인자를 공백으로 구분하고 그 뒤에 줄 바꿈을 출력합니다.
를 사용 echo "$x"
하면 전체 x
변수가 에 따라 단일 단어가 bash
되므로 분할되지 않습니다. 다음과 같이 확인할 수 있습니다.
pax> function count {
...> echo $#
...> }
pax> count 1 2 3
3
pax> count a b c d
4
pax> count $x
4
pax> count "$x"
1
여기에서 count
함수는 주어진 인수의 수를 간단히 출력합니다. 1 2 3
및 a b c d
변종 행동을 보여줍니다.
그런 다음 x
변수 에 대한 두 가지 변형으로 시도합니다 . 한 없이 네 개의 단어가 있다는 것을 인용 쇼, "test"
, "1"
, "test"
와 "2"
. 따옴표를 추가하면 만들어 하나 하나 개의 단어 "test 1\ntest 2"
.
이는 줄 바꿈을 포함 하는 IFS (Internal Field Separator) 변수 때문입니다.
$ cat xx1
1
2
$ A=`cat xx1`
$ echo $A
1 2
$ echo "|$IFS|"
|
|
해결 방법은 임시로 줄 바꿈을 포함하지 않도록 IFS를 재설정하는 것입니다 .
$ IFSBAK=$IFS
$ IFS=" "
$ A=`cat xx1` # Can use $() as well
$ echo $A
1
2
$ IFS=$IFSBAK
IFS에 대한이 끔찍한 변화를 되돌리려면 :
IFS=$IFSBAK
echo "$(IFS=''; cat text.txt)"
Bash -ge 4에는 표준 입력에서 배열 변수로 행을 읽는 맵 파일이 내장되어 있습니다.
help mapfile
mapfile < file.txt lines
printf "%s" "${lines[@]}"
mapfile -t < file.txt lines # strip trailing newlines
printf "%s\n" "${lines[@]}"
또한보십시오:
http://bash-hackers.org/wiki/doku.php/commands/builtin/mapfile
이 envdir
유틸리티는이를 수행하는 쉬운 방법을 제공합니다. envdir
파일을 사용하여 환경 변수를 나타내며 파일 이름은 env var 이름에 매핑되고 파일 내용은 env var 값에 매핑됩니다. 파일 내용에 줄 바꿈이 포함되어 있으면 env var도 마찬가지입니다.