Что бы это ни стоило, мне нужно делать это довольно часто, и я никогда не могу вспомнить точный способ использования while IFS= read...
, поэтому я определил следующую функцию в своем профиле bash:
# 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
<
сделать целым циклом. Хотя теперь это