Shell(1):变量、常用表达式和数组

一、实现功能

二、变量

 1.自定义变量

2.环境变量

3.位置参数变量

4.预定义变量

三、Shell常用表达式

1.逻辑连接符

2.运算

3. 内置判断测试

4.时间命令

四、Shell 数组

1.Shell 概念

2.定义数组

3.读取数组

4.获取数组的长度

五、参考


 


一、实现功能

Shell变量和常用表达式在生产中经常用到,在此总结,加深一下记忆。

二、变量

 1.自定义变量

注意:变量对大小敏感;号两边不能有空格;中间有空格,需要用双引号引起:p2="test2 helloworld"

(1)变量定义

[root@hadoop sh]# p1=test1
[root@hadoop sh]# p2="test2 helloworld"

(2)变量拼接:$外部添加双引号

[root@hadoop sh]# p3="$p1""$p2"
[root@hadoop sh]# echo $p3
test1test2 helloworld

(3)变量调用

[root@hadoop sh]# echo $p1
test1

(4)所有变量查看set

[root@hadoop sh]# set | grep p1
p1=test1

(5)变量删除unset
 

[root@hadoop sh]# unset p2
[root@hadoop sh]# echo $p2

2.环境变量


(1)    声明环境变量:export

[root@hadoop sh]# export env1="ai ni yi wan nian"
[root@hadoop sh]# echo env1
env1

(2)    查询环境变量:env

[root@hadoop sh]# env | grep env1
env1=ai ni yi wan nian

(3)    删除环境变量unset

[root@hadoop sh]# unset env1


3.位置参数变量

(1)$n:表示第几个参数,将传入的参数保存在位置变量中,以便于在脚本中可以使用这些变量。0表示脚本名称

参考:https://www.jianshu.com/p/d3cd36c97abc

以及:https://www.runoob.com/linux/linux-shell-passing-arguments.html

#!/bin/bash
echo $0    # 当前脚本的文件名(间接运行时还包括绝对路径)。
echo $n    # 传递给脚本或函数的参数。n 是一个数字,表示第几个参数。例如,第一个参数是 $1 。
echo $#    # 传递给脚本或函数的参数个数。
echo $*    # 传递给脚本或函数的所有参数。
echo $@    # 传递给脚本或函数的所有参数。被双引号 (" ") 包含时,与 $* 不同,下面将会讲到。
echo $?    # 上个命令的退出状态,或函数的返回值。
echo $$    # 当前 Shell 进程 ID。对于 Shell 脚本,就是这些脚本所在的进程 ID。
echo $_    # 上一个命令的最后一个参数
echo $!    # 后台运行的最后一个进程的 ID 号
echo ${@:2} # 从第2个开始取参数

运行
./input.sh 1 2 3 4 5

结果
./input.sh

5
1 2 3 4 5
1 2 3 4 5
0
55784
55784

2 3 4 5

(2)$*:命令行中所有运行参数和$#:运行参数地个数

[root@hadoop sh]# vi parameter2.sh
#!/bin/bash

echo $*
echo $#
运行
[root@hadoop sh]# ./parameter2.sh 1 2 3         
1 2 3
3

(3)$@和$*区别
$* 和 $@ 都表示传递给函数或脚本的所有参数
-》不被双引号" "包含时:
都以"$1" "$2" … "$n" 的形式输出所有参数。
-》被双引号" "包含时:
"$*" 会将所有的参数作为一个整体,以"$1 $2 … $n"的形式输出所有参数;"$@" 会将各个参数分开,以"$1" "$2" … "$n" 的形式输出所有参数。

[root@hadoop sh]# vi parameter4.sh
#!/bin/bash
echo "\$*=" $*
echo "\"\$*\"=" "$*"
echo "\$@=" $@
echo "\"\$@\"=" "$@"
echo "print each param from \$*"
for var in $*
do
echo "$var"
done
echo "print each param from \$@"
for var in $@
do
echo "$var"
done
echo "print each param from \"\$*\""
for var in "$*"
do
echo "$var"
done
echo "print each param from \"\$@\""
for var in "$@"
do
echo "$var"
done

运行:
[root@hadoop sh]# ./parameter4.sh a b c d
$*= a b c d
"$*"= a b c d
$@= a b c d
"$@"= a b c d
print each param from $*
a
b
c
d
print each param from $@
a
b
c
d
print each param from "$*"
a b c d
print each param from "$@"
a
b
c
d
其中\是转义字符,代表$只是一个字符串

或者实例

#!/bin/bash
# author:菜鸟教程
# url:www.runoob.com

echo "-- \$* 演示 ---"
for i in "$*"; do
    echo $i
done

echo "-- \$@ 演示 ---"
for i in "$@"; do
    echo $i
done

输出结果
$ chmod +x test.sh 
$ ./test.sh 1 2 3
-- $* 演示 ---
1 2 3
-- $@ 演示 ---
1
2
3

4.预定义变量

(1)$?:检测上一条命令是对还是错

[root@hadoop sh]# ls /
bin   dev       etc   lib    lost+found  misc  net  passwd  root  selinux  sys  usr
boot  dump.rdb  home  lib64  media       mnt   opt  proc    sbin  srv      tmp  var
[root@hadoop sh]# echo $0
-bash
[root@hadoop sh]# echo $?
0
[root@hadoop sh]# ls /lll666
ls: cannot access /lll666: No such file or directory
[root@hadoop sh]# echo $?
2


三、Shell常用表达式

1.逻辑连接符

(1)“A && B”:逻辑与,A执行成功,B才执行;A失败,B不执行

[root@hadoop sh]# ls /misf3fd && echo world
ls: cannot access /misf3fd: No such file or directory
[root@hadoop sh]# ls /root && echo world       
anaconda-ks.cfg  Documents  install.log         ml-100k.zip  passwd    Public  somefile   testfile.txt
Desktop          Downloads  install.log.syslog  Music        Pictures  shell   Templates  Videos
world

(2)“A || B”:逻辑或,A成功,B不执行;A失败,B执行
例如:A失败,B执行

[root@hadoop sh]# ls /misf3fd || echo world  
ls: cannot access /misf3fd: No such file or directory
world

A成功,B不执行

[root@hadoop sh]# ls /root || echo world     
anaconda-ks.cfg  Documents  install.log         ml-100k.zip  passwd    Public  somefile   testfile.txt
Desktop          Downloads  install.log.syslog  Music        Pictures  shell   Templates  Videos

(3)分号”;” :无逻辑关系,顺序执行

[root@hadoop sh]# ls /misf3fd ; echo world    
ls: cannot access /misf3fd: No such file or directory
world


2.运算

(1)中括号

[root@hadoop sh]# echo $[a+b]
7
[root@hadoop sh]# echo $[$a+$b]
7
[root@hadoop sh]# echo $[$a-$b]
-1
[root@hadoop sh]# echo $[a-b]  
-1

(2)小括号

[root@hadoop sh]# echo $((a-b))
-1
[root@hadoop sh]# echo $(($a-$b))
-1

(3)表达式expr

[root@hadoop sh]# expr $a + $b
7

备注:+两侧一定要有空格

3. 内置判断测试

 (1)字符串

==:相等,

!=:不等,

-z:如果字符串为空,则返回真,

-n:如果字符串不为空,则返回真.例如:

[root@hadoop sh]# [ $a == $b ]
[root@hadoop sh]# echo $?
1

备注:$?等于0,则为正确,不为0则为错误。

[root@hadoop sh]# [ $a != $b ] 
[root@hadoop sh]# echo $?     
0

[root@hadoop sh]# [ -z $a ]
[root@hadoop sh]# echo $?  
1
返回1,证明a不为空。

(2)数字
 
eq等于

ne不等于

lt小于

le小于等于

gt大于

ge大于等于,例如:

[root@hadoop sh]# a=3;b=4
[root@hadoop sh]# [ $a -eq $b ]
[root@hadoop sh]# echo $?
1        -》a和b不相等

[root@hadoop sh]# [ $a -ne $b ] 
[root@hadoop sh]# echo $?      
0        -》a和b不相等

[root@hadoop sh]# [ $a -lt $b ]  
[root@hadoop sh]# echo $?      
0    -》a小于b

备注:!=等也可以

(3)文件

-e 文件名 :如果文件名存在即为真
-f: 文件名:文件存在,并且是一个普通文件,而不是目录,则返回真
-d 文件名: 判断文件是否存在,而且是一个目录,则返回真
-r 文件名: 如果文件名存在且可读则为真
-w 文件名: 如果文件名存在且可写则为真
-x 文件名 : 如果文件名存在且可执行则为真

[root@hadoop sh]# [ -e parameter.sh ]
[root@hadoop sh]# echo $?
0

[root@hadoop sh]# ll
total 16
-rwxr-xr-x. 1 root root  30 Nov 13 09:14 parameter2.sh
-rwxr-xr-x. 1 root root  37 Nov 13 09:16 parameter3.sh
-rwxr-xr-x. 1 root root 364 Nov 13 10:02 parameter4.sh
-rwxr--r--. 1 root root  45 Nov 13 08:49 parameter.sh
[root@hadoop sh]# [ -x parameter.sh ]  
[root@hadoop sh]# echo $?        
0    -》可执行
[root@hadoop sh]# [ -w parameter.sh ] 
[root@hadoop sh]# echo $?            
0    -》可写

4.时间命令

(1)查看当前系统时间

[root@hadoop sh]# date
Wed Nov 13 10:36:21 CST 2019

(2)设置时间

# date -s "2019-11-11 12:01:00"

(3)按照固定格式输出时间,使用”+”在+后面添加下列格式即可,

%H:小时(00-23)
%M:分钟(00-59)
%d:日(01-31)
%Y:完整年份(0000-9999)
%S:秒(00-60)

[root@hadoop sh]# date "+%Y-%m-%d"
2019-11-13
[root@hadoop sh]# date "+%y-%m-%d"
19-11-13

(4)昨天

$ date  +"%Y%m%d" -d  "+n days"
20190122

四、Shell 数组

1.Shell 概念

数组用括号来表示,元素用"空格"符号分割开,语法格式如下:

array_name=(value1 value2 ... valuen)

2.定义数组

#!/bin/bash
# author:菜鸟教程
# url:www.runoob.com
my_array=(A B "C" D)

或者使用下标来定义数组:
array_name[0]=value0
array_name[1]=value1
array_name[2]=value2

3.读取数组

${array_name[index]}->获取数组中的某一个元素
实例

#!/bin/bash
# author:菜鸟教程
# url:www.runoob.com

my_array=(A B "C" D)

echo "第一个元素为: ${my_array[0]}"
echo "第二个元素为: ${my_array[1]}"
echo "第三个元素为: ${my_array[2]}"
echo "第四个元素为: ${my_array[3]}"

执行脚本,输出结果如下所示:

$ chmod +x test.sh 
$ ./test.sh
第一个元素为: A
第二个元素为: B
第三个元素为: C
第四个元素为: D

->获取数组中的所有元素
使用@ 或 * 可以获取数组中的所有元素,例如:

#!/bin/bash
# author:菜鸟教程
# url:www.runoob.com

my_array[0]=A
my_array[1]=B
my_array[2]=C
my_array[3]=D

echo "数组的元素为: ${my_array[*]}"
echo "数组的元素为: ${my_array[@]}"

执行脚本,输出结果如下所示:

$ chmod +x test.sh 
$ ./test.sh
数组的元素为: A B C D
数组的元素为: A B C D

4.获取数组的长度

获取数组长度的方法与获取字符串长度的方法相同,例如:

#!/bin/bash
# author:菜鸟教程
# url:www.runoob.com

my_array[0]=A
my_array[1]=B
my_array[2]=C
my_array[3]=D

echo "数组元素个数为: ${#my_array[*]}"
echo "数组元素个数为: ${#my_array[@]}"

执行脚本,输出结果如下所示:

$ chmod +x test.sh 
$ ./test.sh
数组元素个数为: 4
数组元素个数为: 4

五、参考

1.https://www.cnblogs.com/xd502djj/p/8963832.html

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值