一、shell简介
1.shell是什么
Linux操作系统的核心是kernal(内核),当应用程序在执行时,需要调用计算机硬件的cpu、内存等资源,程序将指令发送给内核执行。为了防止程序发送一些恶意指令导致损坏内核,在内核和应用程序接口之间,设置一个中间层,称为shell。
shell: 一个可以解释shell规定的语法命令的解释器。解释器负责将应用程序发送的指令,进行检查,合法后交给内核解释执行,并返回结果。
shell命令: shell解释器要求的指定语法编写的命令。
shell脚本: 多条shell命令,可以编写在一个文件中,文件中的指令,可以按照顺序执行,我们就将这个文件称为shell脚本。
2.shell中的解释器
使用 $SHELL变量查看当前系统默认的解释器类型,shell支持多种不同风格的解释器,通过/etc/shells文件查看。默认使用 /bin/bash作为shell命令解释器。
在终端中输入: cat /etc/shells
等价于/bin/bash -c ‘cat /etc/shells’
默认/bin/bash必须接一个脚本,作为输入!如果是一条命令,需要加-c (command)
3.Linux中的常用目录
/bin: linux用户常用的命令
/sbin(super user bin): root用户(管理员)使用的常用命令
4.脚本的编写及执行
- 编写要求
① 声明: #!/bin/bash
② 正文: 必须是shell解释器能否解释的命令 - 脚本的执行
① bash / sh + 脚本
特点: 新开一个bash执行脚本,一旦脚本执行完毕,bash自动关闭!
② ./ 脚本,前提是当前用户对脚本有执行权限,使用当前默认的解释器执行脚本。
特点: 新开一个bash执行脚本,一旦脚本执行完毕,bash自动关闭!
③ source / . + 脚本 使用当前默认的解释器执行脚本,并不要求当前用户对脚本有执行权限。
特点: 在当前bash执行脚本
二、变量操作
1.基本操作
增: 变量名=变量值
删: unset 变量名
改: 变量名=变量值
查: echo $变量名
查看当前bash所有定义的变量: set
2.关键字
特殊关键字:
readonly : 用来修饰一个只读(不能修改,删除)变量。
export: 导出,将一个变量提升为全局变量。
局部变量: 默认变量只在定义变量的bash中有效。
如果希望在bash-a访问bash-b中定义的变量!
要求:
①bash-b不能关闭
②让bash-b将变量提升为全局变量,才能访问到!
注意:
①变量赋值时,值全部以字符串存在,无法进行运算!
②赋值的值中有空格,需要使用引号引起来
单引号: 不能识$等特殊字符,不能脱义
双引号: 可以脱义$
③``,作用是将引号中的命令执行的结果赋值给变量
`命令`等价于 $(命令)
3.变量的生命周期:
在第一次新增时产生
变量在执行unset时,撤销,失效。
关闭当前bash,所有定义的变量也不会存在。
4.特殊变量
$?:上一条命令的返回值,在bash中,如果返回值为0,代表上一条命令执行成功!
$@:参数列表
$*:参数列表 在使用"$*"时,将整个参数列表作为一个参数!
$#:参数个数
$0-n:
$0:参数名
$1-$n:第n个参数
${n}:获取第10个以上的参数
5.运算符
基本语法
1)$((运算式)) 或 $[运算式]
2)expr + , - , \*, /, % 加,减,乘,除,取余
注意:
1)expr运算符间要有空格;
2)*号需要转义为\*,否则会被视为通配符;
6.条件判断
基本语法
[ condition ](注意condition前后要有空格)
注意:条件非空即为true,[ atguigu ]返回true,[] 返回false。
常用判断条件
(1)两个整数之间比较
= 字符串比较
-lt 小于(less than) -le 小于等于(less equal)
-eq 等于(equal) -gt 大于(greater than)
-ge 大于等于(greater equal) -ne 不等于(Not equal)
(2)按照文件权限进行判断
-r 有读的权限(read) -w 有写的权限(write)
-x 有执行的权限(execute)
(3)按照文件类型进行判断
-f 文件存在并且是一个常规的文件(file)
-e 文件存在(existence) -d 文件存在并是一个目录(directory)
-s 文件存在且不为空 -L 文件存在且是一个链接(link)
7.read读取控制台输入
#!/bin/bash
#提示7秒内,读取控制台输入的名称
read -t 7 -p "Enter your name in 7 seconds " NAME
echo $NAME
三、流程控制
1.if判断
- (1)[ 条件判断式 ],中括号和条件判断式之间必须有空格
- (2)if后要有空格
#! /bin/bash
if [ $1 -eq 1 ]
then
echo "你输入的是1"
elif [ $1 -eq 2 ]
then
echo "你输入的是2"
elif [ $1 -eq 3 ]
then
echo "你输入的是3"
else echo "你输入的不是1,2,3"
fi
2.case语句
- case行尾必须为单词“in”,每一个模式匹配必须以右括号“)”结束。
- 双分号“;;”表示命令序列结束,相当于java中的break。
- 最后的“*)”表示默认模式,相当于java中的default。
#!/bin/bash
#读取用户输入的参数
case $1 in
"1")
echo "用户输入1"
;;
"2")
echo "用户输入2"
;;
*)
echo "用户输入其他"
;;
esac
3.for循环
#!/bin/bash
#计算1-100的值
s=0
for((i=0;i<=100;i++))
do
s=$[$s+$i]
done
echo $s
4.while循环
#!/bin/bash
s=0
i=1
while [ $i -le 100 ]
do
s=$[$s+$i]
i=$[$i+1]
done
echo $s
四、函数
1.系统函数
-
basename
basename [string / pathname] [suffix] suffix为后缀,如果suffix被指定了,basename会将pathname或string中的suffix去掉。
#截取该 /home/wuyik/hello.txt路径的文件名称
[wuyik@hadoop101 datas]$ basename /home/wuyik/hello.txt
hello.txt
[wuyik@hadoop101 datas]$ basename /home/wuyik/hello.txt .txt
hello
-
dirname
dirname 文件绝对路径 功能描述:从给定的包含绝对路径的文件名中去除文件名(非目录的部分),然后返回剩下的路径(目录的部分)
#获取hello.txt文件的路径
[wuyik@hadoop101 ~]$ dirname /home/wuyik/hello.txt
/home/wuyik
2.自定义函数
- 基本语法
function funname[()]
{
Action;
[return int;]
}
funname
- 注意事项
(1)必须在调用函数地方之前,先声明函数,shell脚本是逐行运行。不会像其它语言一样先编译。
(2)函数返回值,只能通过$?系统变量获得,可以显示加:return返回,如果不加,将以最后一条命令运行结果,作为返回值。return后跟数值n(0-255) - 举例
#!/bin/bash
#计算两个输入参数的和
function sum()
{
s=0
s=$[ $1 + $2 ]
echo "$s"
}
read -p "Please input the number1: " n1;
read -p "Please input the number2: " n2;
sum $n1 $n2;
五、Shell工具
1.wc
wc命令用来计算数字。利用wc指令我们可以计算文件的Byte数、字数或是列数,若不指定文件名称,或是所给予的文件名为“-”,则wc指令会从标准输入设备读取数据。
- 基本用法
wc [选项参数] filename - 参数说明
选项参数 | 功能 |
---|---|
-l | 统计文件行数 |
-w | 统计文件的单词数 |
-m | 统计文件的字符数 |
-c | 统计文件的字节数 |
2.cut
cut的工作就是“剪”,具体的说就是在文件中负责剪切数据用的。cut 命令从文件的每一行剪切字节、字符和字段并将这些字节、字符和字段输出。
- 基本用法
cut [选项参数] filename
说明:默认分隔符是制表符 - 参数说明
选项参数 | 功能 |
---|---|
-f | f为fileds,列号,提取第几列 |
-d | d为Descriptor分隔符,按照指定分隔符分割列 |
3.sed
sed是一种流编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”,接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有改变,除非你使用重定向存储输出。
- 基本用法
sed [选项参数] ‘command’ filename - 参数说明
选项参数 | 功能 |
---|---|
-e | 直接在指令列模式上进行sed的动作编辑。 |
- 命令功能描述
命令 | 功能描述 |
---|---|
a | 新增,a的后面可以接字串,在下一行出现 |
d | 删除 |
s | 查找并替换 |
4.awk
一个强大的文本分析工具,把文件逐行的读入,以空格为默认分隔符将每行切片,切开的部分再进行分析处理。
- 基本用法
awk [选项参数] ‘pattern1{action1} pattern2{action2}…’ filename
pattern:表示AWK在数据中查找的内容,就是匹配模式
action:在找到匹配内容时所执行的一系列命令 - 参数说明
选项参数 | 功能 |
---|---|
-F | 指定输入文件折分隔符 |
-v | 赋值一个用户定义变量 |
- awk的内置变量
变量 | 说明 |
---|---|
FILENAME | 文件名 |
NR | 已读的记录数(行号) |
NF | 浏览记录的域的个数(切割后列的个数) |
5.sort
sort命令是在Linux里非常有用,它将文件进行排序,并将排序结果标准输出。默认情况以第一个字符串的字典顺序来排序。
- 基本语法
sort(选项)(参数) - 参数说明
选项 | 说明 |
---|---|
-n | 依照数值的大小排序 |
-r | 以相反的顺序来排序 |
-t | 设置排序时所用的分隔字符,默认使用TAB |
-k | 指定需要排序的列 |
-u | u为unique的缩写,即如果出现相同的数据,只出现一行 |