1.shell的解析器
1.1.Linux提供的Shell解析器
常用/bin/sh和/bin/bash
1.2.sh 和 bash的关系
说明使用sh系统实际调用的还是bash
1.3.Centos默认解析器
/bin/bash
2.Shell编程入门
以#!/bin/bash开头
2.1.举例
执行脚本方式./ 和 bash sh 三种
./命令需要执行权限,其它两个不需要,因为./实际是自己执行,其它两个是系统内置的shell在执行。
2.2.举例2
在/opt/study_sh目录下创建文件yang00.txt,并将i love you输入到文件中。
vi yang00.txt出结果
3.变量
3.1.系统变量
包括USER,PWD,HOME等。
3.2.定义变量
1.直接声明即可,比如NAME=xie,等号两边不能有空格,变量值有空格需要用双引号包含,变量默认都是字符串
2.撤销变量用unset,比如unset NAME3,单申明为readoly 的不能撤销。
3.export 变量名,把变量提升为全局变量,供其它shell调用。
3.3.特殊变量$n
n代表数字,比如$0,$1,$2
$0代表脚本名称,其它数字代表变量
执行脚本时,赋予变量值,比如在parameter.sh定义了3个变量:$1,$2,$3,执行sh parameter.sh xie love y
3.4.特殊变量$#
$#获取所有输入参数的个数,常用于循环。
#!/bin/bash
echo “$0 $1 $2 $3“
echo $#
3.5.特殊变量$*,$@
$*和$@代表命令行中的所有参数,
区别:$*把所有参数当做一个整体,$@会把参数区别对待。
3.6.特殊变量$?
返回上一条命令的自行状态,上一条命令执行正确返回0,否则返回其它数字(什么数由命令决定)
4.运算符
4.1.基本语法
- $((运算式)) 或者 $[运算式]
- expr + 、-、*、/、 %,分别为加、减、乘、除、取余,注意expr运算符之间要有空格。
4.2.案例
计算(5-1)*2: expr `expr 5 - 1` * 2 ,括号要用expr一次和esc键下方的`包含。
$运算符
5.条件判断
5.1.基本语法
[condition](注意condition前后要有空格)
注意:条件非空即为true,[xie]返回true,[] 返回false。
5.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.3.举例
1 数字之间的比较
2 文件权限判断
3 文件判断
4 多条件判断
&& 表示前一条命令执行成功时,才执行后一条命令。
|| 表示上一条命令执行失败后,才执行下一条命令
6.流程控制
6.1.if判断
6.1.1.基本语法
if[条件判断式];then
程序
fi
或者
if [条件判断式]
then
程序
else
程序
fi
注意事项:
(1)[条件判断式],中括号和条件判断式之间必须有空格
(2)if后要有空格
6.1.2.举例
#!/bin/bash
if [$1 -eq “1“]
then
echo “xie smart“
elif [$1 -eq “2“]
then
echo “y beautiful“
else
echo “xie l y“
fi
6.2.case语句
6.2.1.基本语法
case $变量名 in
"值1")
如果变量的值等于值1,则执行程序1
;;
“值2“)
如果变量的值等于值2,则执行程序2
;;
…省略其他分支…
*)
如果变量的值都不是以上的值,则执行此程序
;;
esac
注意事项:
- case行尾必须为单词“in“,每一个模式匹配必须以右括号“)“结束。
- 双分号“ ;;“表示命令序列结束,相当于java中的break。
最后的“*)“表示默认模式,相当于java中的default。
6.2.2.举例
#!/bin/bash
case $1 in
“a“)
echo “a xie“
;;
“b“)
echo “b wu“
;;
*)
echo “cheng“
;;
esac
6.3.for循环
6.3.1.基本语法1
for (( 初始值;循环控制条件;变量变化 ))
do
程序
done
6.3.2.举例
#!/bin/bash
total=0
for((s=0;s\<$1;s++))
do
total=$[$total+$s]
done
echo $total
6.3.3.基本语法2
for 变量 in 值1 值2 值3…
do
程序
done
6.3.4.举例
#!/bin/bash
for i in $*
do
echo “i love $i“
done
注意如果把$*换成$@输出结果一样。但是把$*换成“$*“会有差别
没有循环值,仍然会循环一遍,而且有值会输出成一行
把“$*“换成“$@“结果也不一样。
“$@“和$@、$* 输出的结果一样
6.4.while循环
6.4.1.基本语法
while [条件判断式]
do
程序
done
6.4.2.举例
#!/bin/bash
s=0
i=1
while [$i -le 20]
do
i=$[$i+1]
s=$[$i+$s]
done
echo $s
7.read读取控制台输入
7.1.基本语法
read(选项)(参数)
选项:
-p:指定读取值时的提示符;
-t:指定读取值时等待的时间(秒)。
参数
变量:指定读取值的变量名
7.2.举例
5秒内输入内容,否则结束。5秒输入内容则展示输入的内容。
#!/bin/bash
read -t 5 -p “please enter your name:“ NAME
echo “your name is $NAME“
8.函数
8.1.系统函数
8.1.1.basename基本语法
basename [string / pathname] [suffix]
功能描述:basename命令会删掉所有的前缀包括最后一个(’/’)字符,然后将字符串显示出来。
选项:
suffix为后缀,如果suffix被指定了,basename会将pathname或string中的suffix去掉。
8.1.2.dirname基本语法
dirname 文件绝对路径
功能描述:从给定的包含绝对路径的文件名中去除文件名(非目录的部分),然后返回剩下的路径(目录的部分)
8.2.自定义函数
8.2.1.语法
[function] funname[()]
{
Action;
[return int;]
}
funname
解释:中括号的都是可写可不写,funname表示调用函数,funname可接参数。
经验技巧
(1)必须在调用函数地方之前,先声明函数,shell脚本是逐行运行。不会像其它语言一样先编译。
(2)函数返回值,只能通过$?系统变量获得,可以显示加:return返回,如果不加,将以最后一条命令运行结果,作为返回值。return后跟数值n(0-255)
8.2.2.举例
#!/bin/bash
function sum()
{
c=$[$1+$2]
echo “计算结果是:$c“
}
read -t 5 -p “输入第一个值:“ salary
read -t 5 -p “输入第二个值:“ age
sum $salary $age;
9.Shell工具
9.1.cut命令
cut的工作就是“剪“,具体的说就是在文件中负责剪切数据用的。cut 命令从文件的每一行剪切 字节、字符和字段并将这些字节、字符和字段输出。
9.1.1.基本用法
cut [选项参数] filename
说明:默认分隔符是制表符
选项参数说明
-f | 列号,提取第几列 |
---|---|
-d | 分隔符,按照指定分隔符分割列 |
9.1.2.举例
数据文件
- 以空格切割,并取第二列的值
- 以空格切割,并取第二列和之后的值
3.切割第二和第三列
4.切割出yy
5.切割IP地址
9.2.sed 命令
sed是一种流编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间“, 接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复, 直到文件末尾。文件内容并没有改变,除非你使用重定向存储输出。
9.2.1.基本用法
sed [选项参数] 'command' filename
- 选项参数说明
选项参数 | 功能 |
---|---|
-e | 直接在指令列模式上进行sed的动作编辑。 |
- 命令功能描述
命令 | 功能描述 |
---|---|
a | 新增,a的后面可以接字串,在下一行出现 |
d | 删除 |
s | 查找并替换 |
9.2.2.举例
数据文件
1.在第一行后添加re love
2.删除包含aa的行
3.将u替换成U(全局替换用/g)
9.3.awk 命令
一个强大的文本分析工具,把文件逐行的读入,以空格为默认分隔符将每行切片,切开的部分再进行分析处理。
9.3.1.基本用法
awk [选项参数] 'pattern1{action1} pattern2{action2}...' filename
pattern:表示AWK在数据中查找的内容,就是匹配模式(正则表达式)
action:在找到匹配内容时所执行的一系列命令
选项参数说明
-F | 指定输入文件折分隔符 |
---|---|
-v | 赋值一个用户定义变量 |
9.3.2.举例
数据准备
1.搜索passwd文件以bin关键字开头的所有行,并输出该行的第7列。
^bin表示以bin开头,$bin表示以bin结尾,注意:只有匹配了pattern的行才会执行action
2.搜索passwd文件以daemon关键字开头的所有行,并输出该行的第1列和第7列,中间以“,“号分割。
3.将passwd文件中的用户id增加数值10并输出
awk的内置变量
FILENAME | 文件名 |
---|---|
NR | 已读的记录数 |
NF | 浏览记录的域的个数(切割后,列的个数) |
1.搜索passwd文件以daemon关键字开头的所有行,并输出文件名,所在的行数和列数
2.找IP
9.4.sort 命令
sort命令是在Linux里非常有用,它将文件进行排序,并将排序结果标准输出。
9.4.1.基本语法
sort(选项)(参数)
选项 | 说明 |
---|---|
-n | 依照数值的大小排序 |
-r | 以相反的顺序来排序 |
-t | 设置排序时所用的分隔字符 |
-k | 指定需要排序的列 |
参数:指定待排序的文件列表
9.4.2.举例
数据文件
1.以空格分隔,并以第三列排序