写了个脚本管理本地的项目路径,脚本里多处地方用到了 ls -1 $ROOT_PATH
来列举有哪些项目。
后期脚本使用过程中,又想按照时间顺序来列举项目名,所以需要把 ls -1 $ROOT_PATH
改成 ls -1t $ROOT_PATH
。
于是思考了能否把 ls -1t $ROOT_PATH
单独提出来作为一个函数,减少重复代码,方便维护。
但发现 SHELL 这方面相比 C 有欠缺。
语法上,shell 函数仅支持返回整数,函数执行完后,使用 $? 来获取函数返回值。
想要函数返回字符串可以在函数内部输出字符串,然后在函数外部抓取。
#!/bin/sh
func()
{
echo "abc"
}
echo `func`
echo $(func)
特别点,让函数返回命令执行结果,比如 ls -1 $ROOT_PATH
,它可能会返回多个字符串。
#!/bin/sh
func()
{
echo `ls -1 $ROOT_PATH`
}
for i in `func`
do
echo $i
done
上面的脚本会把 $ROOT_PATH 目录下的文件一行一行打印出来,类似如下:
file1
file2
file3
如果在函数后面再接个管道处理数据,比如统计文件数量,写成下面这样:
#!/bin/sh
func()
{
echo `ls -1 $ROOT_PATH`
}
echo `func | wc -l`
会发现统计出来的数量为 1,显然不对,原因是 echo ls -1 $ROOT_PATH
的返回值被认为是一个一个变量,只有第一个变量经过管道传到后面去了。
我们在命令两边加上双引号,返回值就变成了一个变量,如下:
#!/bin/sh
func()
{
echo "`ls -1 $ROOT_PATH`"
}
echo `func | wc -l`
此时统计出来的数量就对了。