正则表达式
正则表达式使用单个字符串来描述、匹配一系列符合某个语法规则的字符串。在很多文本编辑器里,正则表达式通常被用来检索、替换那些符合某个模式的文本。在 Linux 中,grep,sed,awk 等文本处理工具都支持通过正则表达式进行模式匹配。
常用特殊字符
特殊字符:^
^ 匹配一行的开头
例如匹配出所有以a开头的行
特殊字符:$
$匹配一行的结束
例如找出所有以bash结尾的行
^$匹配的是空行
特殊字符:.
. 匹配一个任意的字符,几个点就代表中间有几个字符
特殊字符:*
* 不单独使用,他和上一个字符连用,表示匹配上一个字符 0 次或多次,例如
.*匹配的就是任意一个字符出现任意次,就是一个字符串
字符区间 : [ ]
[ ] 表示匹配某个范围内的一个字符,例如
[6,8]------匹配 6 或者 8
[0-9]------匹配一个 0-9 的数字
[0-9]*------匹配任意长度的数字字符串
[a-z]------匹配一个 a-z 之间的字符
[a-z]* ------匹配任意长度的字母字符串
[a-c, e-f]-匹配 a-c 或者 e-f 之间的任意字符
特殊字符:\
\ 表示转义,并不会单独使用。由于所有特殊字符都有其特定匹配模式,当我们想匹配某一特殊字符本身时(例如,我想找出所有包含 '$' 的行),就会碰到困难。此时我们就要将转义字符和特殊字符连用,来表示特殊字符本身,例如
匹配一个手机号
{9}指定出现的次数,属于扩展写法,前面要加上-E,表示要支持这种方法
文本处理工具
cut
cut 的工作就是“剪”,具体的说就是在文件中负责剪切数据用的。cut 命令从文件的每一行剪切字节、字符和字段并将这些字节、字符和字段输出。
基本语法:cat 选项 filename
示例:截取以“ ”为分隔符的文件第一列内容
awk
文本分析工具,把文件逐行的读入,以空格为默认分隔符将每行切片,切开的部分再进行分析处理。
基本语法:awk 选项 '/匹配模式/ 执行的动作' ... '/匹配模式/ 执行的动作' filename
搜索 passwd 文件以 root 关键字开头的所有行,并输出该行的第 7 列
搜索 passwd 文件以 root 关键字开头的所有行,并输出该行的第 1 ,6列和第 7 列,中间以“,”号分割
只显示/etc/passwd 的第一列和第七列,以逗号分割,且在所有行前面添加列名 user,shell 在最后一行添加"gxy"
将 passwd 文件中的用户 id 增1
awk 的内置变量
统计 passwd 文件名,每行的行号,列号
综合应用案例
发送消息
利用 Linux 自带的 mesg 和 write 工具,向其它用户发送消息。需求:实现一个向某个用户快速发送消息的脚本,输入用户名作为第一个参数,后面直接跟要发送的消息。脚本需要检测用户是否登录在系统中、是否打开消息功能,以及当前发送消息是否为空。
#!/bin/bash
#查看用户是否登录
#-i忽略大小写,-m 1表示后面要跟的最大数
login_user=$(who | grep -i -m 1 $1 | awk '{print $1}')
#-z判断是否为空
if [ -z $login_user ]
then
echo "$1 不在线!"
exit
fi
#查看用户是否开启消息接收功能
is_allowed=$(who -T | grep -i -m 1 $1 | awk -F' ' '{print $1}')
if [ $is_allowed != "+" ]
then
echo "$1 没有开启消息功能! "
exit
fi
#确认是否有消息发送
if [ -z $2 ]
then
echo "没有消息发送!"
exit
fi
#从参数中获取要发送的消息
whole_msg=$(echo $* | cut -d " " -f 2-)
#whole_msg=$2
#获取用户登录的终端
user_terminal=$(who | grep -i -m 1 $1 | awk '{print $1}')
#写入要发送的消息
echo $whole_msg | write $login_user $user_terminal
if [ $? != 0 ]
then
echo "发送失败!"
exit
else
echo "发送成功!"
fi
exit