我有这个bash脚本来填充一个文本文件,我想让它更简单,更简单,使它更有效率,有没有人有任何想法,我怎么能这样做?
$vi
function displayHelp
{
echo "Use '-f' to set the file to be used "
echo "Use '-s' to sort the data bya column"
echo "Use '-m' to output the rows which match this expression"
}
function displayColumn
{
columnnumber="$2"
awk '{print $'$columnnumber'}' $1
}
function displayParameter
{
parameter="$3"
columnnumber="$2"
awk -v s=$3 -v c=$2 '$c ~ s { print $0 }' $1
}
while getopts f:s:m:h opt
do
case "$opt" in
h) displayHelp;;
f) filepath="$OPTARG";;
s) column="$OPTARG"
displayColumn $filepath $column
;;
m) searchParam="$OPTARG"
displayParameter $filepath $column $searchParam
;;
esac
done
答案 0 :(得分:2)
在displayColumn()
中,您没有使用-v
变量传递,但在displayParameter()
中您是。您应始终使用-v
而不是嵌入shell变量。
同样在displayParameter()
中,您可以分配两个变量,但绝不使用它们。
扩展时应始终引用shell变量。当它们单独出现时,没有必要在作业的右侧引用它们。
如果这是你想要的,那么-f
就没有强制要求了。如果没有提供它(及其必需的参数),您的脚本将尝试从stdin
读取(这可能是您想要的)。
没有强制要求-m
和-s
。如果两者都不存在,AWK命令将输出错误消息。
通常,必须将参数作为位置参数处理,并且选项标志应该用于选项(及其参数)。
您的问题可能更适合Code Review。