1.运算符(expr:空格)
1.1:“ ( ( 运 算 式 ) ) ” 或 “ ((运算式))” 或 “ ((运算式))”或“[运算式]”
1.2:expr + , - , *, /, % 加,减,乘,除,取余
注意:
expr运算符间要有空格
①
expr `expr 2 + 3` \* 4
②采用$[运算式]
S=$[(2+3)*4]
echo $S
③echo $(((2+1)*7))
2.条件判断
2.1:基本语法
[ condition ](注意condition前后要有空格
)
注意:条件非空即为true,[ atguigu ]返回true,[] 返回false。
2.2:常用判断条件
(1)两个整数之间比较
= 字符串比较( 注意:必须加空格,否则就是一个非空字符串,始终返回true )
例如:[ a = b ])
代码 | 意思 | 由来 |
---|---|---|
-lt | 小于 | less than |
-le | 小于等于 | less equal |
-eq | 等于 | equal |
-gt | 大于 | greater than |
-ge | 大于等于 | greater equal |
-ne | 不等于 | Not equal |
(1)23是否大于等于22
[ 23 -ge 22 ]
echo $?
(2)按照文件权限进行判断
代码 | 意思 | 由来 |
---|---|---|
-r | 有读的权限 | read |
-w | 写的权限 | write |
-x | 执行的权限 | execute |
(3)按照文件类型进行判断
代码 | 意思 | 由来 |
---|---|---|
-f | 文件存在并且是一个常规的文件 | file |
-e | 文件存在 | existence |
-d | 文件存在并是一个目录 | directory |
(1)helloworld.sh是否具有写权限
[ -w helloworld.sh ]
echo $?
(2)/home/atguigu/cls.txt目录中的文件是否存在
[ -e /home/atguigu/cls.txt ]
echo $?
(3)多条件判断
&& 表示前一条命令执行成功时,才执行后一条命令
|| 表示上一条命令执行失败后,才执行下一条命令
[yu@hadoop100 ~]$ [ condition ] && echo OK || echo notok
OK
[yu@hadoop100 ~]$ [ condition ] && [ ] || echo notok
notok
3.流程控制
3.1:if判断
1.基础结构
if [ 条件判断式 ]
then
程序
fi
2.完整结构
if [条件表达式]
then
程序
elif [条件表达式]
then
程序
else
程序
fi
注意事项:
(1)[ 条件判断式 ],中括号和条件判断式之间必须有空格
(2)if后要有空格
if [ $1 -eq "1" ]
then
echo "和1匹配"
elif [ $1 -eq "2" ]
then
echo "和2匹配"
fi
3.2:case语句
1.基本语法
case $变量名 in
"值1")
如果变量的值等于值1,则执行程序1
;;
"值2")
如果变量的值等于值2,则执行程序2
;;
…省略其他分支…
*)
如果变量的值都不是以上的值,则执行此程序
;;
esac
注意事项:
1)case行尾必须为单词“in”,每一个模式匹配必须以右括号“)”结束。
2)双分号“;;”表示命令序列结束,相当于java中的break。
3)最后的“*)”表示默认模式,相当于java中的default。
case $1 in
"1")
echo "和1匹配"
;;
"2")
echo "和2匹配"
;;
*)
echo "无匹配"
;;
esac
3.3:for循环
a.语法1
for (( 初始值;循环控制条件;变量变化 ))
do
程序
done
计算0加到100
s=0
for((i=0;i<=100;i++))
do
s=$[$s+$i]
done
echo $s
b.语法2
for 变量 in 值1 值2 值3…
do
程序
done
输出所有变量:
for i in $*
do
echo $i
done
$*和$@区别:注意是加了双引号后,才有区别
for i in "$*"
do
echo $i
done
echo "------------"
for i in "$@"
do
echo $i
done
结果:
当它们被双引号“”包含时:
“$*”:会将所有的参数作为一个==整体==,以“$1 $2 …$n”的形式输出所有参数
“$@”:会将各个参数==分开==,以“$1” “$2”…”$n”的形式输出所有参数。
3.4:while循环
while [ 条件判断式 ]
do
程序
done
从1加到100
a=0
i=1
while [ $i -le 100 ]
do
a=$[$a+$i]
i=$[$i+1]
done
echo $a
4.read读取控制台输入
4.1.基本语法
read(选项)(参数)
选项:
-p:指定读取值时的提示符;
-t:指定读取值时等待的时间(秒)。
参数
变量:指定读取值的变量名
4.2.案例:
提示7秒内,读取控制台输入的名称
read -t 7 -p "7秒内输入名字: " NAME
echo $NAME
5.shell函数
5.1系统函数
1.basename (去除前缀)
basename [string / pathname] [suffix]
(功能描述:basename命令会删掉所有的前缀包括最后一个(‘/’)字符,然后将字符串显示出来。
2.dirname(去除文件名,获取路径)
5.2自定义函数
[ function ] funname[()]
{
Action;
[return int;]
}
funname
(1)必须在调用函数地方之前,先声明函数,shell脚本是逐行运行。不会像其它语言一样先编译。
(2)函数返回值,只能通过$?系统变量获得,可以显示加:return返回,如果不加,将以最后一条命令运行结果,作为返回值。return后跟数值n(0-255)
6.shell工具
6.1:cut:剪切并输出
cut [选项参数] filename
说明:默认分隔符是制表符
选项参数 | 功能 |
---|---|
-f | 列号,提取第几列 |
-d | 分隔符,按照指定分隔符分割列 |
1、切割第一列
cut -d " " -f 1 cut.txt
2、切割第二、三列
cut -d " " -f 2,3 a.txt
3、从第一行中切割出“北”
cat a.txt | grep "北" | cut -d " " -f 1
4、选取系统PATH变量值,第2个“:”开始后的所有路径:
3-表示第三列以后的所有列
echo $PATH
echo $PATH | cut -d ":" -f 3-
5、切割ifconfig 后打印的IP地址
6.2、sed
sed是一种流编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”,
接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。
接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有改变,除非你使用重定向存储输出。
用法:
sed [选项参数] ‘command’ filename
选项参数 | 功能 |
---|---|
-e | 直接在指令列模式上进行sed的动作编辑 |
命令 | 功能描述 |
---|---|
a | 新增,a的后面可以接字串,在下一行出现 |
d | 删除 |
s | 查找并替换 |
6.2.1、将“西安 兵马俑”这个插入到a.txt第二行下,打印。
sed '2a 西安 兵马俑' a.txt
6.2.2、 删除a.txt文件所有包含北的行
sed '/北/d' a.txt
6.2.3、将a.txt文件中‘上’替换为‘洱’
sed 's/上/洱/g' a.txt
注意:‘g’表示global,全部替换
6.2.4、将a.txt文件中的第二行删除 + 并将’上’替换为’洱’
sed -e '2d' -e 's/上/洱/g' a.txt
注意:如果执行多条相同的命令,不加-e只会执行一个
6.3 awk
一个强大的文本分析工具,把文件逐行的读入,以空格为默认分隔符将每行切片,切开的部分再进行分析处理。
awk [选项参数] ‘pattern1{action1} pattern2{action2}...’ filename
pattern:表示AWK在数据中查找的内容,就是匹配模式
action:在找到匹配内容时所执行的一系列命令
注意:这里的模式匹配需要使用单引号,因为双引号会对正则的一些特殊符号处理
选项参数 | 功能 |
---|---|
-F | 指定输入文件拆分隔符 |
-v | 赋值一个用户定义变量 |
1.数据准备:
sudo cp /etc/passwd ./
2.搜索passwd文件以root关键字开头的所有行,使用冒号切分,并输出该行的第7列。
awk -F: '/^root/{print $7}' passwd /bin/bash
6.4sort
文件进行排序,并将排序结果标准输出。
sort (选项) (参数)
选项 | 说明 |
---|---|
-n | 依照数值大小排序 |
-r | 以相反的顺序来排序 |
-t | 设置排序所用的分割字符 |
-k | 指定需要排序的列 |
(1)默认排序
sort a.txt
(2)按照“:”分割后的第三列倒序排序。
sort -t : -nrk 3 sort.txt