不要在循环中调用sed,这将非常慢.
您可以将索引文件转换为sed脚本,然后在数据文件上调用sed一次:
sed -i.bak "$(sed 's/$/d/' index.txt)" file.txt
或者,正如@ Hazzard17指出的那样,忽略不包含数字的行:
script=$(sed -n '/^[[:blank:]]*[[:digit:]]\+[[:blank:]]*$/ s/$/d/p' index.txt)
sed -i.bak "$script" file.txt
一个演示:
$seq 20000 | sed 's/^/line/' > file.txt
$wc file.txt
20000 20000 188894 file.txt
$seq 20000 | while read n; do [[ $RANDOM -le 5000 ]] && echo $n; done > index.txt
$wc index.txt
3083 3083 16789 index.txt
$sed -i.bak "$(sed 's/$/d/' index.txt)" file.txt
$wc -l file.txt{,.bak}
16917 file.txt
20000 file.txt.bak
36917 total
要将文件读入数组,您可以执行以下操作:
mapfile -t indices < index.txt
for i in "${indices[@]}"; do ...; done
或者只是遍历文件
while IFS= read -r i; do ...; done < index.txt