目录
书写带参数的shell脚本:
1.1参数化实例
创建bash1.sh
#!/bin/bash
echo "Shell 传递参数实例!";
echo "第一个参数为:$1";
echo "参数个数为:$#";
echo "传递的参数作为一个字符串显示:$*";
运行脚本:
root@ubuntu:/home/lulu/Desktop/Test# ./bash1.sh
Shell 传递参数实例!
第一个参数为:
参数个数为:0
传递的参数作为一个字符串显示:
root@ubuntu:/home/lulu/Desktop/Test# ./bash1.sh 1,2,3,4
Shell 传递参数实例!
第一个参数为:1,2,3,4
参数个数为:1
传递的参数作为一个字符串显示:1,2,3,4
root@ubuntu:/home/lulu/Desktop/Test# ./bash1.sh 1 2 3 4
Shell 传递参数实例!
第一个参数为:1
参数个数为:4
传递的参数作为一个字符串显示:1 2 3 4
$* 与 $@ 区别:
相同点:都是引用所有参数。
不同点:只有在双引号中体现出来。假设在脚本运行时写了三个参数 1、2、3,,则 " * " 等价于 "1 2 3"(传递了一个参数),而 "@" 等价于 "1" "2" "3"(传递了三个参数)。
创建脚本bash.sh:
for i in "$*"; do
echo $i
done;
root@ubuntu:/home/lulu/Desktop/Test# chmod +x bash.sh
root@ubuntu:/home/lulu/Desktop/Test# ./bash.sh 1 2
1 2
创建脚本bash2.sh
for i in "$@"; do
echo $i
done;
root@ubuntu:/home/lulu/Desktop/Test# chmod +x bash2.sh
root@ubuntu:/home/lulu/Desktop/Test# ./bash2.sh 1 2
1
2
echo "执行脚本名称:$0";
echo "获取第一个参数:$1";
echo "获取第二个参数$2";
echo "获取到的参数$*";
echo "获取参数个数$#";
echo "获取的参数每个参数都是一个(str):$@";
echo "读取当前参数(pid):$$";
root@ubuntu:/home/lulu/Desktop/Test# sh test.sh
执行脚本名称:test.sh
获取第一个参数:
获取第二个参数
获取到的参数
获取参数个数0
获取的参数每个参数都是一个(str):
读取当前参数(pid):20680
root@ubuntu:/home/lulu/Desktop/Test# sh test.sh 1 2 3
执行脚本名称:test.sh
获取第一个参数:1
获取第二个参数2
获取到的参数1 2 3
获取参数个数3
获取的参数每个参数都是一个(str):1 2 3
读取当前参数(pid):20685
1.2参数处理说明
$# 传递到脚本或函数的参数个数
$* 以一个单字符串显示所有向脚本传递的参数
$$ 脚本运行的当前进程ID号
$! 后台运行的最后一个进程的ID号
$@ 与$*相同,但是使用时加引号,并在引号中返回每个参数。
$- 显示Shell使用的当前选项,与set命令功能相同。
$? 显示最后命令的退出状态。0表示没有错误,其他任何值表明有错误。
1.3带返回值的参数
funWithReturn(){
echo "这个函数会对输入的两个数字进行相加运算..."
echo "输入第一个数字: "
read aNum
echo "输入第二个数字: "
read anotherNum
echo "两个数字分别为 $aNum 和 $anotherNum !"
return $(($aNum+$anotherNum))
}
funWithReturn
echo "输入的两个数字之和为 $? !"
脚本执行:
root@ubuntu:/home/lulu/Documents# ./funWithReturn.sh
这个函数会对输入的两个数字进行相加运算...
输入第一个数字:
1
输入第二个数字:
2
两个数字分别为 1 和 2 !
root@ubuntu:/home/lulu/Documents# echo "输入的两个数字之和为 $? !"
输入的两个数字之和为 3 !
关于文件名带空格的处理方法:
#example ./test.sh 2022\ a.text 2022\ b.txt
##添加这行代码
IFS=$(echo -en "\n\b")
OLD_File=$1
NEW_FIle=${2}
comm -23 grep -E "reg" ${OLD_File} ${NEW_FIle}
关于文件名带空格的处理方法:
#example ./test.sh 2022\ a.text 2022\ b.txt
##添加这行代码
IFS=$(echo -en "\n\b")
OLD_File=$1
NEW_FIle=${2}
comm -23 grep -E "reg" ${OLD_File} ${NEW_FIle}
shell判断问题
推荐使用
if [[ "x$inputValue" == "xy" || "x$inputValue" == "xY" ]]
then
fi;
防止出现异常
read超时
function input_name(){
echo -e "===================================================================="
echo -e "enter input_name function"
echo -e "===================================================================="
echo -e "do you want input a new names instead of the previous name(please input y/n)"; read -t inputValue
if [[ "x$inputValue" == "xy" || "x$inputValue" == "xY" ]]
then
echo -e "the previous names is: ${name}, do you want input another name(please input y/n)?"; read inputValue
if [[ "x$inputValue" == "xy" || "x$inputValue" == "xY" ]]
then
echo -e "the previous name is: ${name}, please choose one of the following name input"
nameList=$(cat names.txt | grep name |awk {'print $1'} | sort -u | paste -sd " ")
nameArr=(`echo ${nameList} |awk '{len=split($0,a," ");for(i=1;i<=len;i++) print a[i]}'`)
echo -e "${nameList}"
echo -e "please input name:(if you not input name during 30 seconds, we will use default name:${name} )"; read -t $timeout newName
fi;
fi;
echo -e ""
if [[ -n $newName ]]
then
## 数组包含
if [[ "${nameArr[@]}" =~ "$newName" ]]
then
name=$newName
else
echo -e "the name (${name}) you input is not in nameList(${nameList})"
exit 0;
fi;
fi;
echo -e "do you want input new namespace during executing menu x (please input y/n)"; read -t inputValue
echo -e "current name is: ${name}"
}