写了个脚本管理本地的项目路径,脚本里多处地方用到了 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`
此时统计出来的数量就对了。
文章讨论了如何在Shell脚本中创建函数来返回命令执行的结果,特别是当命令如`ls-1t$ROOT_PATH`返回多个字符串时。通过在函数内部使用echo和外部捕获输出,可以实现返回多个字符串的效果。同时,指出了在管道操作中正确处理函数返回值以避免数据丢失的问题,强调了使用双引号的重要性。
913

被折叠的 条评论
为什么被折叠?



