我有这个while循环,在下面我试图得到下面列出的结果。循环的目的是通过BookDB.txt查找与标题或作者匹配的所有模式,在找到之后,循环将打印出来,但目前我的问题是,我试图在所有匹配模式的列表"Number of Record: X“之前插入一行。
number of records found: X
Title,Author,Price,QtyAvailable,QtySold我不知道把这行放在哪里才能得到记录,因为如果我把它放进循环中,它就会被复制,并且我试图避免重复找到的记录行的数量。
#matching item 1
number of records found: X
Title,Author,Price,QtyAvailable,QtySold
#matching item 2
number of records found: X
Title,Author,Price,QtyAvailable,QtySold但是我不确定该如何修改我的代码来实现它。需要帮助,文件的输入是
Title:Author:Price:QtyAvailable:QtySold
function search_book
{
echo "Enter Title: "
read title_r
echo "Enter Author: "
read author_r
while read -r result
do
title=$(echo "$result" | cut -f 1 -d ":")
author=$(echo "$result" | cut -f 2 -d ":")
price=$(echo "$result" | cut -f 3 -d ":")
qty_ava=$(echo "$result" | cut -f 4 -d":")
qty_sold=$(echo "$result" | cut -f 5 -d ":")
if echo "$title" | grep -iq "$title_r" && echo "$author" | grep -iq "$author_r";
then
record=$(grep -io "$title" BookDB.txt | sort | uniq -c)
echo -e "$title,$author,$price,$qty_ava,$qty_sold"
fi
done < ./BookDB.txt
echo ""
echo "Number of records found: " $record | cut -f1-6 -d" "
echo ""
}发布于 2015-01-14 01:35:59
您只需将记录行放在while循环之前,并先回显记录,然后循环将在程序中运行,并显示您的匹配模式列表,而不需要任何记录复制。
function search_book
{
echo "Enter Title: "
read title_r
echo "Enter Author: "
read author_r
record=$(grep -io "$title_r" BookDB.txt | sort | uniq -c)
echo "Number of records found: " $record | cut -f1-6 -d" "
while read -r result
do
title=$(echo "$result" | cut -f 1 -d ":")
author=$(echo "$result" | cut -f 2 -d ":")
price=$(echo "$result" | cut -f 3 -d ":")
qty_ava=$(echo "$result" | cut -f 4 -d":")
qty_sold=$(echo "$result" | cut -f 5 -d ":")
if echo "$title" | grep -iq "$title_r" && echo "$author" | grep -iq "$author_r";
then
#record=$(grep -io "$title" BookDB.txt | sort | uniq -c)
echo -e "$title,$author,"\$"$price,$qty_ava,$qty_sold"
fi
done < ./BookDB.txt
echo ""
#echo "Number of records found: " $record | cut -f1-6 -d" "
echo ""
main_menu
}https://stackoverflow.com/questions/27921993
复制相似问题