Для чого це потрібно робити мені досить часто, і я ніколи не пам'ятаю точний спосіб використання while IFS= read...
, тому я визначив наступну функцію в своєму баш-профілі:
# iterate the line of a file and call input function
iterlines() {
(( $# < 2 )) && { echo "Usage: iterlines <File> <Callback>"; return; }
local File=$1
local Func=$2
n=$(cat "$File" | wc -l)
for (( i=1; i<=n; i++ )); do
"$Func" "$(sed "${i}q;d" "$File")"
done
}
Ця функція спочатку визначає кількість рядків у файлі, потім використовує sed
для вилучення рядка за рядком і передає кожну рядок як єдиний рядковий аргумент будь-якій заданій функції. Я гадаю, що це може бути дуже неефективним з великими файлами, але це для мене поки не було проблемою (пропозиції, як покращити цей прийом, звичайно).
Використання досить солодке ІМО:
>> cat example.txt # note the use of spaces, whitespace, etc.
a/path
This is a sentence.
"wi\th quotes"
$End
>> iterlines example.txt echo # preserves quotes, $ and whitespace
a/path
This is a sentence.
"wi\th quotes"
$End
>> x() { echo "$#"; }; iterlines example.txt x # line always passed as single input string
1
1
1
1
1
<
потрапити в цілий цикл. Хоча це має цілком сенс зараз я це бачив