文章目录
1. shell 脚本入门
-
脚本格式:
- 脚本以#!/bin/bash 开头(指定解析器)
-
运行脚本(有两种方法)
- 改变权限为755
- 采用解析器 例如
- bash 名字
- sh 名字
2. shell中的变量
1. 系统变量
- 常用的系统变量
- PWD,USER等
2. 自定义变量
- 基本语法
- 定义变量: 变量=值
- 撤销变量: unset 变量
- 声明静态变量 : readonly 变量,不能unset了
- 变量定义规则
- 变量名称可以由字母、数字和下划线组成,但是不能以数字开头,环境变量名建议大写。
- 等号两侧不能有空格
- 在bash中,变量默认类型都是字符串类型,无法直接进行数值运算。
- 变量的值如果有空格,需要使用双引号或单引号括起来。
- 可把变量提升为全局环境变量,可供其他Shell程序使用------>export 变量名
3. 特殊变量
-
变量:$n
- 功能描述:n为数字,$0代表该脚本名称,$1-{10}
-
变量: $#
- 功能描述:获取所有输入参数个数,常用于循环
-
变量:$*
- 这个变量代表命令行中所有的参数,$*把所有的参数看成一个整体
-
变量:$@
- 这个变量也代表命令行中所有的参数,不过$@把每个参数区分对待
-
变量:$?
- 功能描述:最后一次执行的命令的返回状态。如果这个变量的值为0,证明上一个命令正确执行;如果这个变量的值为非0(具体是哪个数,由命令自己来决定),则证明上一个命令执行不正确了。
3. 运算符
1. 基本语法
- “[运算式]”
- expr + , - , *, /, % 加,减,乘,除,取余
- 注意:expr运算符间要有空格
4.条件判断
1. 基本语法:
- [ condition ](注意condition前后要有空格)
- 注意:条件非空即为true,[ atguigu ]返回true,[] 返回false。
2.常用判断条件
格式 | 解释 |
---|---|
(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) |
&& | 表示前一条命令执行成功时,才执行后一条命令 |
|| | 表示上一条命令执行失败后,才执行下一条命令 |
5.流程控制
1. if判断
1.基本语法
if [ 条件判断式 ];then
程序
fi
或者
if [ 条件判断式 ]
then
程序
fi
- 注意事项:
- [ 条件判断式 ],中括号和条件判断式之间必须有空格
- if后要有空格
2. case 判断
- 基本语法
case $变量名 in
"值1")
如果变量的值等于值1,则执行程序1
;;
"值2")
如果变量的值等于值2,则执行程序2
;;
…省略其他分支…
*)
如果变量的值都不是以上的值,则执行此程序
;;
esac
3. for 循环
- 基本语法
for (( 初始值;循环控制条件;变量变化 ))
do
程序
done
- 例子
s=0
for((i=0;i<=100;i++))
do
s=$[$s+$i]
done
echo $s
- 有些例子还可以这样
for 变量 in 值1 值2 值3…
do
程序
done
- 例子
for i in $*
do
echo "ban zhang love $i "
done
- 比较@区别
- @都表示传递给函数或脚本的所有参数,不被双引号“”包含时,都以$1,n的形式输出所有参数。
- 当它们被双引号“”包含时,“$*”会将所有的参数作为一个整体,以“$1 n”的形式输出所有参数;“$@”会将各个参数分开,以“$1” “n”的形式输出所有参数。
4. while 循环
- 基本语法
while [ 条件判断式 ]
do
程序
done
- 例子
s=0
i=1
while [ $i -le 100 ]
do
s=$[$s+$i]
i=$[$i+1]
done
echo $s
6. read 读取控制条输入
- 基本语法
- read (选项)(参数)
- 选项:
- -p : 指定读取值时的提示符
- -t: 指定读取值时等待的时间(秒)
- 参数:
- 变量 : 指定读取值得变量名
- 例子
read -t 7 -p "Enter your name in 7 seconds " NAME
echo $NAME
7. 函数
1. 系统函数
- basename 基本语法
- basename [string / pathname] [suffix]
- 功能描述:basename命令会删掉所有的前缀包括最后一个(‘/’)字符,然后将字符串显示出来。
- 选项:
suffix为后缀,如果suffix被指定了,basename会将pathname或string中的suffix去掉。
- dirname 基本语法
- dirname 文件绝对路径
- 功能描述:从给定的包含绝对路径的文件名中去除文件名(非目录的部分),然后返回剩下的路径(目录的部分)
2. 自定义函数
- 基本语法
[ function ] funname[()]1
{
Action;
[return int;]
}
funname
- 使用函数的技巧
- 必须在调用函数地方之前,先声明函数,shell脚本是逐行运行。不会像其它语言一样先编译。
- 函数返回值,只能通过$?系统变量获得,可以显示加:return返回,如果不加,将以最后一条命令运行结果,作为返回值。return后跟数值n(0-255)
- 例子
function sum()
{
s=0
s=$[ $1 + $2 ]
echo "$s"
}
8 shell 工具
cut
就是文件中负责剪切数据用的,从文件的每一行剪切字节,字符,和字段并输出等等
- 基本用法
- cut [选项参数] filename
- 说明:默认分隔符是制表符
- 参数:
选项参数 | 功能 |
---|---|
-f | 列号,提取第几列 |
-d | 分隔符,按照指定分隔符分割列 |
sed
- 解释:一种流编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”,接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有改变,除非你使用重定向存储输出。
这里只是粗略的解释
- 基本用法
- sed [选项参数] ‘command’ filename
- 选项参数 功能
- -e 直接在指令列模式上进行sed的动作编辑。
- 命令功能描述
命令 | 功能描述 |
---|---|
a | 新增,a的后面可以接字符串,在下一行显示 |
d | 删除 |
s | 查找并替换 |
3. awk
- 解释:一个强大的文本分析工具,把文件逐行的读入,以空格为默认分隔符将每行切片,切开的部分再进行分析处理。
- 基本用法
- awk [选项参数] ‘pattern1{action1} pattern2{action2}…’ filename
- pattern:表示AWK在数据中查找的内容,就是匹配模式
- action:在找到匹配内容时所执行的一系列命令
- 选项参数说明
选项参数 | 功能 |
---|---|
-F | 指定输入文件折分隔符 |
-v | 赋值一个用户定义变量 |
- awk 的内置变量
变量 | 说明 |
---|---|
FILENAME | 文件名 |
NR | 已读的记录数 |
NF | 浏览记录的域的个数(切割后,列的个数) |
4. sout
- 就是将文件进行排序,然后将结果输出出来
- 基本语法
- sort (选项)(参数)
- 选项
选项 | 说明 |
---|---|
-n | 依照数值的大小排序 |
-r | 以相反的顺序来排序 |
-t | 设置排序时所用的分隔字符 |
-k | 指定需要排序的列 |