Użyj while read
pętli:
: > another_file ## Truncate file.
while IFS= read -r LINE; do
command --option "$LINE" >> another_file
done < file
Innym jest przekierowanie wyjścia według bloku:
while IFS= read -r LINE; do
command --option "$LINE"
done < file > another_file
Ostatnim jest otwarcie pliku:
exec 4> another_file
while IFS= read -r LINE; do
command --option "$LINE" >&4
echo xyz ## Another optional command that sends output to stdout.
done < file
Jeśli jedno z poleceń czyta wejście, byłby to dobry pomysł, aby użyć innego fd dla wejścia więc polecenia nie zje go (tutaj zakładając ksh
, zsh
albo bash
za -u 3
, użyj <&3
zamiast przenośnie):
while IFS= read -ru 3 LINE; do
...
done 3< file
Wreszcie, aby zaakceptować argumenty, możesz:
#!/bin/bash
FILE=$1
ANOTHER_FILE=$2
exec 4> "$ANOTHER_FILE"
while IFS= read -ru 3 LINE; do
command --option "$LINE" >&4
done 3< "$FILE"
Który mógłby działać jako:
bash script.sh file another_file
Dodatkowy pomysł. Za bash
pomocą readarray
:
readarray -t LINES < "$FILE"
for LINE in "${LINES[@]}"; do
...
done
Uwaga: IFS=
można pominąć, jeśli nie przeszkadza ci przycinanie wartości linii spacji wiodących i końcowych.
<file xargs -L 1 -I{} command --option {} other args