概述
Shell是一个命令行解释器,接受应用程序 / 用户命令,然后调用操作系统内核
Linux 提供的 Shell 解析器:
[atguigu@hadoop101 ~]$ cat /etc/shells
/bin/sh
/bin/bash
/usr/bin/sh
/usr/bin/bash
/bin/tcsh
/bin/csh
Shell 脚本入门
脚本格式
脚本以#!/bin/bash开头(指定解析器)
脚本执行方式
- 采用 bash 或 sh+脚本的相对路径或绝对路径(不用赋予脚本+x 权限)
- 采用输入脚本的绝对路径或相对路径执行脚本(必须具有可执行权限+x)
变量
系统预定义变量
$HOME、$PWD、$SHELL、$USER 等
自定义变量
定义变量:变量名=变量值,注意,=号前后不能有空格
撤销变量:unset 变量名
声明静态变量:readonly 变量,注意:不能 unse
环境变量名建议大写
在 bash 中,变量默认类型都是字符串类型,无法直接进行数值运算
变量的值如果有空格,需要使用双引号或单引号括起来
特殊变量
$n (功能描述:n 为数字,$0 代表该脚本名称,$1-$9 代表第一到第九个参数,十以上的参数,十以上的参数需要用大括号包含,如${10})
$# (功能描述:获取所有输入参数个数,常用于循环,判断参数的个数是否正确以及加强脚本的健壮性)
$* (功能描述:这个变量代表命令行中所有的参数,$*把所有的参数看成一个整体)
$@ (功能描述:这个变量也代表命令行中所有的参数,不过$@把每个参数区分对待)
运算符
“$((运算式))” 或 “$[运算式]”
条件判断
基本语法
test condition 条件非空即为 true,[ atguigu ]返回 true,[ ] 返回false
condition 前后要有空格
判断条件
整数比较
-eq 等于 (equal) -ne 不等于(not equal)
-lt 小于 (less than) -le 小于等于(less equal)
-gt 大于 (greater than) -ge 大于等于(greater equal
如果是字符串之间的比较 ,用等号“=”判断相等;用“!=”判断不等
文件权限判断
-r 有读的权限(read)
-w 有写的权限(write)
-x 有执行的权限(execute)
文件类型判断
-e 文件存在(existence)
-f 文件存在并且是一个常规的文件(file)
-d 文件存在并且是一个目录(directory)
流程控制
if 判断
if [ 条件判断式 ]
then
程序
elif [ 条件判断式 ]
then
程序
else
程序
fi
[ 条件判断式 ],中括号和条件判断式之间必须有空格
if 后要有空格
case 语句
case $变量名 in
"值 1")
如果变量的值等于值 1,则执行程序 1
;;
"值 2")
如果变量的值等于值 2,则执行程序 2
;;
…省略其他分支…
*)
如果变量的值都不是以上的值,则执行此程序
;;
esac
for 循环
跟c差不多
for (( 初始值;循环控制条件;变量变化 ))
do
程序
done
while 循环
while [ 条件判断式 ]
do
程序
done
read 读取控制台
read (选项) (参数)
①选项:
-p:指定读取值时的提示符;
-t:指定读取值时等待的时间(秒)如果-t 不加表示一直等待
②参数
变量:指定读取值的变量名
类似scanf函数
函数
系统函数
basename
basename [string / pathname] [suffix] (功能描述:basename 命令会删掉所有的前缀包括最后一个(‘/’)字符,然后将字符串显示出来。
basename 可以理解为取路径里的文件名称
选项:suffix 为后缀,如果 suffix 被指定了,basename 会将 pathname 或 string 中的 suffix 去掉
dirname
dirname 文件绝对路径 (功能描述:从给定的包含绝对路径的文件名中去除文件名
(非目录的部分),然后返回剩下的路径(目录的部分))
dirname 可以理解为取文件路径的绝对路径名称
自定义函数
[ function ] funname[()]
{
Action;
[return int;]
}
在调用函数地方之前,必须先声明函数,shell 脚本是逐行运行。不会像其它语言一 样先编译
函数返回值,只能通过$?系统变量获得,可以显示加:return 返回,如果不加,将 以最后一条命令运行结果,作为返回值。return 后跟数值 n(0-255)
正则表达式入门
在 Linux 中,grep,sed,awk 等文本处理工具都支持通过正则表达式进行模式匹配
常规匹配
一串不包含特殊字符的正则表达式匹配它自己
cat /etc/passwd | grep atguig
匹配所有包含 atguigu 的行
常用特殊字符
^str | 匹配一行的开头 |
---|---|
str$ | 匹配一行的结束 |
. | 匹配一个任意的字符 |
* | 表示匹配上一个字符 0 次或多次 |
字符区间(中括号):[ ] | 表示匹配某个范围内的一个字符 |
\ | 表示转义,用于特殊字符 |
文本处理工具
cut
是在文件中负责剪切数据用的。cut 命令从文件的每 一行剪切字节、字符和字段并将这些字节、字符和字段输出
cut [选项参数] filenam
默认分隔符是制表符
参数
-f | 列号,提取第几列 |
---|---|
-d | 分隔符,按照指定分隔符分割列,默认是制表符“\t” |
-c | 按字符进行切割 后加加 n 表示取第几列 比如 -c 1 |
awk
强大的文本分析工具,把文件逐行的读入,以空格为默认分隔符将每行切片,切开的部分再进行分析处理
基本用法
awk [选项参数] ‘/pattern1/{action1} /pattern2/{action2}...’ filename
pattern:表示 awk 在数据中查找的内容,就是匹配模式
action:在找到匹配内容时所执行的一系列命令
参数
-F | 指定输入文件分隔符 |
---|---|
-v | 赋值一个用户定义变量 |