shell 基本用法

shTest.sh

#!/bin/sh

# read 与 $0,$1,$2...${10},${11}..... 都用于获取脚本命令行参数,区别:
前者是shTest.sh 回车后 输入参数
后者是直接在shTest.sh 后面直接加参数,$0获取的是脚本路径以及脚本名,$1获取第一个参数,依次类推,${10}获取的是第10个参数,不能用$10获取第10个参数。

#x=$1

read -p "请输入成绩参数:" x

if [[ "$x" == "" || $x == [a-Z]* ]];then

echo "无输入参数或者输入非法数字!"

exit 5

fi

if [[ $x -ge "90" && $x -le "100" ]];then

echo "A等"

elif [[ "$x" -ge "60" && "$x" -le "90" ]];then

echo "B等"

else

echo "C等"

fi

# echo 测试

echo true

echo "false"

echo 今天是6月27日

echo "今天是6月27日"

echo '今天是6月27日'

#  ` ` 与$() 都表示命令替换的意思,命令替换是指可以先执行` ` 中的命令,将输出结果暂时保存,在适当的地方输出,该反引号内必须有 shell 命令

z=`date`

z1=$(date)

echo $z,$z1

# 单引号' ' 与双引号 " " 的区别:

相同点:都能避免空格带来的困扰,例如: 声明 str=abc def 会报错,但是用引号括起来就好了   str= 'abc def '或者 str= "abc def"

不同点:单引号剥夺了所有字符的特殊含义,即 echo '$z' 会使 $的特殊含义(参数替换)失效,输出: $z 而不会输出日期

双引号则不会,所以他与单引号、反引号、参数替换 等结合起来可以进行很多复杂的组合操作,即echo "$z" ,输出结果与

echo $z 一致,都是当前时间。

# $age ,${age},$(( age )),$[ age ] 的比较
# $age 等价于 ${age}  都是用于参数替换,一般情况下,两者是没有区别的,但是用${ }会比较精确的界定变量名称的范围

echo $ages,${age}s

#$(( age )) 与$[ age ] 都是整数运算符号,用来对整数进行各种运算,如:

e=23

echo $[ $e+1 ]

echo $(( 20*5-12+5 ))

# 双中括号[[ ]] 与单中括号 [ ] 的区别:

# 1.前者中用 >,<,=,!= 比较整型数字和字符串大小不需要转义,在后者中用 >,<,=,!= 比较整型数字和字符串大小需要用\ 转义

#因为[是shell命令,在它包围的表达式是它的命令行参数,所以串比较符>和<需要转义,否则就变成io重定向了。[[是shell关键字,不会做命令行扩展,所以<和>不需要进行转义。但是语法相对严格。

#2.在if条件中两者都不能 直接比较小数的大小,需要调用bc 命令
#3.前者中可以使用正则表达式来匹配,作条件筛选,后者不可以用正则表达式。如:

if [[ "$x" == "" || $x == [a-Z]* ]];then

echo "无输入参数或者输入非法数字!"

exit 5

fi

#4.前者的多个条件用 &&,|| 连接,后者用 -a,-o连接

#5. 两者都可以用以下筛选:

#-eq  等于 应用于:整型比较

#-ne  不等于 应用于:整型比较

#-lt  小于 应用于:整型比较

#-gt  大于 应用于:整型比较

#-le  小于或等于 应用于:整型比较

#-ge  大于或等于 应用于:整型比较

#-z  空字符串

#-n  非空字符串

if [ 'abc' \> 'aad' ];then

echo true

else

echo false

fi

#比较小数的大小,需要调用bc命令为其比较的结果赋值,如果比较的结果为真,则通过bc命令为其赋1,否则赋0
#然后再判断bc之后的结果是为1还是为0来比较原来两个数的大小

w=1.5

w1=5.5

flag=$(echo "$w > $w1" |bc)

#if [ $flag -eq 1 ];then

if [ ` echo "$w > $w1" |bc` = 1 ];then

#if [[ 1>2 ]];then

echo true

else

echo false

fi

if [[ 99+1 -eq 100 ]];then

echo true

else

echo false

fi

#字符替换

#cat某个文件,过滤出含有sags 的所有行,然后将每行的字符串“sags”替换为“这段时间”

#msg =`cat ${result_file} |grep sags |sed 's/sags|/这段时间/g'`


#Shell特殊变量:Shell $0, $#, $*, $@, $?, $$和命令行参数,转载于 https://blog.csdn.net/u011341352/article/details/53215180

  1. 特殊变量列表
  2. 变量 含义
  3. $0 当前脚本的文件名
  4. $n 传递给脚本或函数的参数。n 是一个数字,表示第几个参数。例如,第一个参数是$1,第二个参数是$2
  5. $# 传递给脚本或函数的参数个数。
  6. $* 传递给脚本或函数的所有参数。
  7. $@ 传递给脚本或函数的所有参数。被双引号(" ")包含时,与 $* 稍有不同,下面将会讲到。
  8. $? 上个命令的退出状态,或函数的返回值。一般情况下,大部分命令执行成功会返回 0,失败返回 1
  9. $$ 当前Shell进程ID。对于 Shell 脚本,就是这些脚本所在的进程ID。
  10. $* 和 $@ 的区别
  11. $* 和 $@ 都表示传递给函数或脚本的所有参数,不被双引号(" ")包含时,都以"$1" "$2""$n" 的形式输出所有参数。
  12. 但是当它们被双引号(" ")包含时,"$*" 会将所有的参数作为一个整体,以"$1 $2 … $n"的形式输出所有参数;"$@" 会将各个参数分开,以"$1" "$2""$n" 的形式输出所有参数。
  13. 下面的例子可以清楚的看到 $* 和 $@ 的区别:
  14. #!/bin/bash
  15. echo "\$*=" $*
  16. echo "\"\$*\"=" "$*"
  17. echo "\$@=" $@
  18. echo "\"\$@\"=" "$@"
  19. echo "print each param from \$*"
  20. for var in $*
  21. do
  22. echo "$var"
  23. done
  24. echo "print each param from \$@"
  25. for var in $@
  26. do
  27. echo "$var"
  28. done
  29. echo "print each param from \"\$*\""
  30. for var in "$*"
  31. do
  32. echo "$var"
  33. done
  34. echo "print each param from \"\$@\""
  35. for var in "$@"
  36. do
  37. echo "$var"
  38. done
  39. 执行 ./test.sh "a" "b" "c" "d",看到下面的结果:
  40. $*= a b c d
  41. "$*"= a b c d
  42. $@= a b c d
  43. "$@"= a b c d
  44. print each param from $*
  45. a
  46. b
  47. c
  48. d
  49. print each param from $@
  50. a
  51. b
  52. c
  53. d
  54. print each param from "$*"
  55. a b c d
  56. print each param from "$@"
  57. a
  58. b
  59. c
  60. d
  61. 说明:双引号包含时,"$*"的参数被当做一个整体,而"$@"还是遍历每一个参数


Linux—shell中$(( ))、$( )、``与${ }的区别 ,详细比较

转载于https://blog.csdn.net/number_0_0/article/details/73291182


 在bash中, $( )` `(反引号)都是用来作命令替换的。
命令替换与变量替换差不多,都是用来重组命令行的,先完成引号里的命令行,然后将其结果替换出来,再重组成新的命令行。

exp 1

  1. $ echo today is $( date "+%Y-%m-%d")
  2. today is 2014 -07 -01

$( )与``

在操作上,这两者都是达到相应的效果,但是建议使用$( ),理由如下:

  • ``很容易与''搞混乱,尤其对初学者来说。
  • 在多层次的复合替换中,``必须要额外的跳脱处理(反斜线),而$( )比较直观。
  • 最后,$( )的弊端是,并不是所有的类unix系统都支持这种方式,但反引号是肯定支持的。

exp 2

  1. # 将cmd1执行结果作为cmd2参数,再将cmd2结果作为cmd3的参数
  2. cmd3 $(cmd2 $(cmd1))
  3. # 如果是用反引号,直接引用是不行的,还需要作跳脱处理
  4. cmd3 `cmd2 \`cmd1\``

${ }变量替换

一般情况下,$var${var}是没有区别的,但是用${ }会比较精确的界定变量名称的范围

  1. $ A=B
  2. $ echo ${A}B
  3. BB

取路径、文件名、后缀
先赋值一个变量为一个路径,如下:
file=/dir1/dir2/dir3/my.file.txt

命令解释结果
${file#*/}拿掉第一条 / 及其左边的字符串dir1/dir2/dir3/my.file.txt
${file##*/}拿掉最后一条 / 及其左边的字符串my.file.txt
${file#*.}拿掉第一个 . 及其左边的字符串file.txt
${file##*.}拿掉最后一个 . 及其左边的字符串txt
${file%/*}拿掉最后一条 / 及其右边的字符串/dir1/dir2/dir3
${file%%/*}拿掉第一条 / 及其右边的字符串(空值)
${file%.*}拿掉最后一个 . 及其右边的字符串/dir1/dir2/dir3/my.file
${file%%.*}拿掉第一个 . 及其右边的字符串/dir1/dir2/dir3/my

记忆方法如下:

  • # 是去掉左边(在键盘上 # 在 $ 之左边)
  • % 是去掉右边(在键盘上 % 在 $ 之右边)
  • 单一符号是最小匹配;两个符号是最大匹配
  • *是用来匹配不要的字符,也就是想要去掉的那部分
  • 还有指定字符分隔号,与*配合,决定取哪部分

取子串及替换

命令解释结果
${file:0:5}提取最左边的 5 个字节/dir1
${file:5:5}提取第 5 个字节右边的连续 5 个字节/dir2
${file/dir/path}将第一个 dir 提换为 path/path1/dir2/dir3/my.file.txt
${file//dir/path}将全部 dir 提换为 path/path1/path2/path3/my.file.txt
${#file}获取变量长度27
根据状态为变量赋值
命令解释备注
${file-my.file.txt}若 $file 没设定,则使用 my.file.txt 作传回值空值及非空值不作处理
${file:-my.file.txt}若 $file 没有设定或为空值,则使用 my.file.txt 作传回值非空值时不作处理
${file+my.file.txt}若$file 设为空值或非空值,均使用my.file.txt作传回值没设定时不作处理
${file:+my.file.txt}若 $file 为非空值,则使用 my.file.txt 作传回值没设定及空值不作处理
${file=txt}若 $file 没设定,则回传 txt ,并将 $file 赋值为 txt空值及非空值不作处理
${file:=txt}若 $file 没设定或空值,则回传 txt ,将 $file 赋值为txt非空值时不作处理
${file?my.file.txt}若 $file 没设定,则将 my.file.txt 输出至 STDERR空值及非空值不作处理
${file:?my.file.txt}若 $file没设定或空值,则将my.file.txt输出至STDERR非空值时不作处理

tips:
以上的理解在于, 你一定要分清楚 unset 与 null 及 non-null 这三种赋值状态. 一般而言, : 与 null 有关, 若不带 : 的话, null 不受影响, 若带 : 则连 null 也受影响.

数组

  1. A= "a b c def" # 定义字符串
  2. A=(a b c def) # 定义字符数组
命令解释结果
${A[@]}返回数组全部元素a b c def
${A[*]}同上a b c def
${A[0]}返回数组第一个元素a
${#A[@]}返回数组元素总个数4
${#A[*]}同上4
${#A[3]}返回第四个元素的长度,即def的长度3
A[3]=xyz则是将第四个组数重新定义为 xyz

$(( ))与整数运算

bash中整数运算符号

符号功能
+ - * /分别为加、减、乘、除
%余数运算
& | ^ !分别为“AND、OR、XOR、NOT”

在 $(( )) 中的变量名称,可于其前面加 $ 符号来替换,也可以不用。

  1. $ a=5;b=7;c=2
  2. $ echo $((a+b*c))
  3. 19
  4. $ echo $(( $a+ $b* $c))
  5. 19

进制转换
$(( ))可以将其他进制转成十进制数显示出来。用法如下:
echo $((N#xx))
其中,N为进制,xx为该进制下某个数值,命令执行后可以得到该进制数转成十进制后的值。

  1. $ echo $((2 #110)) # 二进制转十进制
  2. 6
  3. $ echo $((16 #2a)) # 十六进制转十进制
  4. 42
  5. $ echo $((8 #11)) # 八进制转十进制
  6. 9

(( ))重定义变量值

  1. $ a=5;b=7
  2. $ ((a++)); echo $a
  3. 6
  4. $ ((a--)); echo $a
  5. 5
$ ((a<b));echo $? 0

使用(( ))作整数测试时,不要跟[ ]的整数测试搞混乱了。


  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值