linux的shell脚本语言笔记

本文介绍了Shell脚本的基础知识,包括脚本的执行方式、变量定义、条件判断及流程控制等核心内容。此外还详细解释了正则表达式的使用方法。

一·shell脚本入门

基本格式:脚本以#!/bin/bash 开头

执行shell脚本语言有多种方式:

第一种:采用 bash 或 sh+脚本的相对路径或绝对路径(不用赋予脚本+x 权限)

第二种:采用输入脚本的绝对路径或相对路径执行脚本(必须具有可执行权限+x)

注意:第一种执行方法,本质是 bash 解析器帮你执行脚本,所以脚本本身不需要执行
权限。第二种执行方法,本质是脚本需要自己执行,所以需要执行权限。
【了解】第三种:在脚本的路径前加上“.”或者 source
二.变量
其中expory 为定义成全局变量
特殊变量中:
$n 其中$0为显示脚本名称,1-9是传入参数
$# 获取所有输入参数个数,常用于循环,判断参数的个数是否正确以及
加强脚本的健壮性。
$?即是打印检查此返回值是否为0或者1
三.条件判断
-eq 等于(equal)
-ne 不等于(not equal)
-lt 小于(less than)
-le 小于等于(less equal)
-gt 大于(greater than)
-ge 大于等于(greater equal)
四.流程控制语句
其中输入字符不能直接使用需要加x去进行区分定义,例如:
bdfe3dd9bd7d4c8b9888fd2befcc71a2.png

正则表达式入门
第一种即是常规表达 不含有特殊的字符
cat /etc/passwd | grep user01
常用特殊字符
1)特殊字符: 匹配一行的开头
cat /etc/passwd | grep ^u
2)特殊字符$ 匹配一行的结束
cat /etc/passwd | grep bash$
3)特殊字符:. 匹配一个任意的字符
cat /etc/passwd | grep r..t
4)特殊字符:* 不单独使用,他和上一个字符连用,表示匹配上一个字符 0 次或多次
echo "helllllo" | grep hel*o
5)字符区间(中括号)[ ]
[ ] 表示匹配某个范围内的一个字符,例如
[6,8]------匹配 6 或者 8
[0-9]------匹配一个 0-9 的数字
[0-9]*------匹配任意长度的数字字符串
[a-z]------匹配一个 a-z 之间的字符
[a-z]* ------匹配任意长度的字母字符串
[a-c, e-f]-匹配 a-c 或者 e-f 之间的任意字符
cat /etc/passwd | grep r[a,b,c]*t
#会匹配 rt,rat, rbt, rabt, rbact,rabccbaaacbt 等等所有行

正则匹配手机号:

echo 19270006626 | grep -E ^1[34589][0-9]{9}$
# 参数 -E 代表着匹配使用{9} 如不是使用则要[0-9] 重复9次
6)特殊字符\
表示转义,并不会单独使用。由于所有特殊字符都有其特定匹配模式,当我们想匹配
某一特殊字符本身时(例如,我想找出所有包含 '$' 的行),就会碰到困难。此时我们就要
将转义字符和特殊字符连用,来表示特殊字符本身
cat /etc/passwd | grep 'a\$b'
文本处理工具

cut

cut 的工作就是,具体的说就是在文件中负责剪切数据用的。cut 命令从文件的每
一行剪切字节、字符和字段并将这些字节、字符和字段输出。
1)基本用法
cut [选项参数] filename
说明:默认分隔符是制表符
2)选项参数说明
选项参数 功能
-f 列号,提取第几列
-d 分隔符,按照指定分隔符分割列,默认是制表符“\t”
-c 按字符进行切割 后加加 n 表示取第几列 比如 -c 1
cut -d " " -f 1 cut.txt

cat /etc/passwd | grep bash$ | cut -d ":" -f -4

例如:

ifconfig | grep netmask | cut -d " " -f 10

 

awk

一个强大的文本分析工具,把文件逐行的读入,以空格为默认分隔符将每行切片,切开
的部分再进行分析处理。
1)基本用法
awk [选项参数] ‘/pattern1/{action1} /pattern2/{action2}...’ filename
pattern:表示 awk 在数据中查找的内容,就是匹配模式
action:在找到匹配内容时所执行的一系列命令
2)选项参数说明
选项参数 功能
-F 指定输入文件分隔符
-v 赋值一个用户定义变量

4)awk 的内置变量
变量 说明
FILENAME 文件名
NR 已读的记录数(行号)
NF 浏览记录的域的个数(切割后,列的个数)
cat /etc/passwd | awk -F ":" '/^root/ {print $7}'
#搜索 passwd 文件以 root 关键字开头的所有行,并输出该行的第 7 列。
cat /etc/passwd | awk -F ":" '/^root/ {print $1","$7}'
#搜索 passwd 文件以 root 关键字开头的所有行,并输出该行的第 1 列和第 7 列,
中间以“,”号分割。
awk -F ":" 'BEGIN{print "user, shell"} {print $1","$7} END{print "heihei,/bin/susu"}' /etc/passwd
#只显示/etc/passwd 的第一列和第七列,以逗号分割,且在所有行前面添加列名 user,shell 在最后一行添加"hiehei,/bin/susu"。
awk -F : '{print "filename:" FILENAME ",linenum:"NR ",col:"NF}' /etc/passwd 
#统计 passwd 文件名,每行的行号,每行的列数
ifconfig | awk '/^$/{print NR}'
#查询 ifconfig 命令输出结果中的空行所在的行号
ifconfig | awk '/netmask/ {print $2}'
#切割 IP

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值