笔记
1、晨考
1、用两种方法,实现将文件中的以# 开头的行把# 去掉
sed -r 's/^#//g' /etc/fstab
cat /etc/fstab | tr -d '^#'
2、将文件中的Hello World 替换成 World Hello
sed -r 's/Hello World/World Hello/g' 7.txt
awk '{print $2,$1}' 7.txt
3、删除一个文本中所有的数字
sed -r 's/[0-9]+//g' 8.txt
cat 8.txt | tr -d '[0-9]+'
2、昨日问题
1、sed包含几个部分
sed [参数] [匹配规则] [操作对象]
1、定位
2、编辑模式
3、今日内容
1、磁盘管理
2、awk
1、参数
2、匹配规则
BEGIN
{}
//
END{}
FS
NR
NF
if
for
自定义变量
4、磁盘管理
Linux系统中磁盘管理就是将硬盘通过挂载的方式挂载到linux文件系统中。
1、挂载磁盘的步骤
1、磁盘分区
2、挂载
2、磁盘分区
fdisk:分区2TB以下的磁盘,最多可以分4个分区
gdisk:分区2TB以上的磁盘,最多可以分128个分区
3、添加一块磁盘
lsblk : 查看本机的磁盘
df -h : 查看本机的分区
4、磁盘分区
n : 新建一个分区
p : 打印分区表
w : 写入磁盘并退出
q : 退出
d : 删除一个分区
5、挂载磁盘分区
1、格式化文件系统
mkfs.xfs /dev/sdb1
6、总结
1、关机
2、添加硬盘
3、创建分区
fdisk /dev/sdb
或
gdisk /dev/sdb
4、格式化文件系统
mkfs.xfs /dev/sdb1
5、挂载
mount /dev/sdb1 /mnt
5、awk
awk主要是用来格式化文本。
1、awk的语法
awk [参数] [处理规则] [操作对象]
2、参数
-F : 指定文本分隔符(默认是以空格作为分隔符)
awk -F'f' '{print $NF}' 9.txt
案例:打印系统所有用户的解析器
awk -F: '{print $NF}' /etc/passwd
3、awk的生命周期
grep、sed和awk都是读一行处理一行,直至处理完成。
1、接收一行作为输入
2、把刚刚读入进来得到文本进行分解
3、使用处理规则处理文本
4、输入一行,赋值给$0,直至处理完成
5、把处理完成之后的所有的数据交给END{}来再次处理
4、awk中的预定义变量
$0 : 代表当前行
[root@localhost ~]# awk -F: '{print $0, "---"}' /etc/passwd
$n :代表第n列
[root@localhost ~]# awk -F: '{print $1}' /etc/passwd
NF :记录当前行的字段数
[root@localhost ~]# awk -F: '{print NF}' /etc/passwd
[root@localhost ~]# awk -F: '{print $NF}' /etc/passwd
NR :用来记录行号
[root@localhost ~]# awk -F: '{print NR}' /etc/passwd
FS :指定文本内容分隔符(默认是空格)
[root@localhost ~]# awk 'BEGIN{FS=":"}{print $NF, $1}' /etc/passwd
FS 的优先级要高于 -F
OFS :指定打印分隔符(默认空格)
[root@localhost ~]# awk -F: 'BEGIN{OFS=" >>> "}{print $NF, $1}' /etc/passwd
5、awk处理规则的执行流程
BEGIN{}
//
{}
END{}
6、awk中的函数
print : 打印
printf :格式化打印
%s : 字符串
%d :数字
- :左对齐
+ :右对齐
15 : 至少占用15字符
[root@localhost ~]# awk -F: 'BEGIN{OFS=" | "}{printf "|%+15s|%-15s|\n", $NF,$1}' /etc/passwd
7、awk中的定位
1、正则表达式
[root@localhost ~]# awk -F: '/root/{print $0}' /etc/passwd
[root@localhost ~]# awk -F: '/^root/{print $0}' /etc/passwd
2、比较表达式
>
<
>=
<=
~ 正则匹配
!~ 正则匹配(取反)
案例:要求打印属组ID大于属主ID的行
[root@localhost ~]# awk -F: '$4 > $3{print $0}' /etc/passwd
案例:结尾包含bash
[root@localhost ~]# awk -F: '$NF ~ /bash/{print $0}' /etc/passwd
案例:结尾不包含bash
[root@localhost ~]# awk -F: '$NF !~ /bash/{print $0}' /etc/passwd
3、逻辑表达式
&& : 逻辑与
|| :逻辑或
! :逻辑非
[root@localhost ~]# awk -F: '$3 + $4 > 2000 && $3 * $4 > 2000{print $0}' /etc/passwd
[root@localhost ~]# awk -F: '$3 + $4 > 2000 || $3 * $4 > 2000{print $0}' /etc/passwd
[root@localhost ~]# awk -F: '!($3 + $4 > 2000){print $0}' /etc/passwd
4、算术表达式
+
-
*
/
%
案例:要求属组 + 属主的ID 大于 2000
[root@localhost ~]# awk -F: '$3 + $4 > 2000{print $0}' /etc/passwd
案例:要求属组 * 属主的ID 大于 2000
[root@localhost ~]# awk -F: '$3 * $4 > 2000{print $0}' /etc/passwd
案例:要求打印偶数行
[root@localhost ~]# awk -F: 'NR % 2 == 0{print $0}' /etc/passwd
案例:要求打印奇数行
[root@localhost ~]# awk -F: 'NR % 2 == 1{print $0}' /etc/passwd
5、条件表达式
==
>
<
>=
<=
案例:要求打印第三行
[root@localhost ~]# awk -F: 'NR == 3{print $0}' /etc/passwd
6、范围表达式
[root@localhost ~]# awk -F: '/^root/,/^ftp/{print $0}' /etc/passwd
8、流程控制
只存在循环之中。
if
[root@localhost ~]# awk -F: '{if($3>$4){print "大于"}else{print "小于或等于"}}' /etc/passwd
if(){}
if(){}else{}
if(){}else if(){}else{}
for
[root@localhost ~]# awk -F: '{for(i=10;i>0;i--){print $0}}' /etc/passwd
for(i="初始值";条件判断;游标){}
while
[root@localhost ~]# awk -F: '{i=1; while(i<10){print $0, i++}}' /etc/passwd
while(条件判断){}
每隔5行,打印一行横线
-------------------------------------------------------------------------
[root@localhost ~]# awk -F: '{if(NR%5==0){print "----------------"}print $0}' /etc/passwd