Bash를 처음 접했고 로컬/전역 변수/하위 쉘에 대해 혼란스러워했습니다. 왜 수정된 변수가 함수 끝에서 인쇄되지 않는지 잘 모르겠습니다. 파일 끝에서 최종 줄 번호와 파일 번호를 인쇄하려고 했지만 그렇게 하면 0만 인쇄됩니다. 지역 변수이기 때문입니다. 수정된 값을 출력할 수 있는 방법이 있나요?
count=0
files=0
find . -type f | while IFC= read -r file;
do
let files=files+1
wc -l $file
count=$(($count+$(wc -l < $file)))
echo "total lines $count ; total files $files"
done
echo $files $count
exit 0
답변1
예. 그러나 이것은 확실히 직관적이지 않습니다. 예를 들어 다음과 같이 작동합니다.
#!/bin/bash
count=0
files=0
while IFS= read -r file;
do
let files=files+1
wc -l $file
count=$(($count+$(wc -l < $file)))
echo "total lines $count ; total files $files"
done < <(find . -type f )
echo "$files $count"
exit 0
이 <(command)
구조는"프로세스 대체"명령의 출력을 "파일"로 볼 수 있습니다. 이런 식으로 루프에 입력하면 스크립트가 예상대로 작동할 수 있습니다.
문제는 파이프( |
)를 사용한다는 것입니다. 이로 인해 while 루프가 별도의 하위 쉘에서 실행되어 외부 변수를 수정할 수 없습니다.
이 기능을 지원하지 않는 셸에서는 <()
하위 셸의 파이프 오른쪽에서 명령을 실행하고 해당 하위 셸에 최종 에코를 포함할 수 있습니다.
#!/bin/bash
files=0
find . -type f | {
while IFC= read -r file;
do
let files=files+1
wc -l $file
count=$(($count+$(wc -l < $file)))
echo "total lines $count ; total files $files"
done
echo "$files $count"
}
exit 0