grep与正则表达式:
1、grep程序
Linux下有文本处理三剑客 - - grep sed awk
grep:文本 行 过滤工具
sed:文本 行 编辑器(流编辑器)
awk:报告生成器(做文本输出格式化)
Linux下有文本处理三剑客 - - grep sed awk
grep:文本 行 过滤工具
sed:文本 行 编辑器(流编辑器)
awk:报告生成器(做文本输出格式化)
grep
包含三个命令:grep egrep fgrep,它们是用来进行 行模式(pattern)匹配的
egrep = grep - E //使用扩展的正则表达式进行匹配
fgrep = fast grep //只使用文件通配符进行匹配
*grep默认使用正则表达式进行文本匹配*
grep的用法:
grep [option]...PATTERN [filename]
grep的常见选项 -- option
-E 支持使用的扩展的正则表达式(ERE) (regexp)
-P 使用perl语言的正则表达式引擎进行搜索(每一种语言的正则表达式引擎都不相同,甚至sed grep awk使用的regexp引擎也不相同
-i 忽略大小
-v 进行反选
-o 仅仅输出匹配的内容(默认输出的是匹配到的行)
--color=auto 语法着色
-n 显示行号
PATTERN--正则表达式
作用:通过一些特殊字符,来表示一类字符内容,然后交给前面的命令来执行;如果使用特殊字符本身含义,就需要 进行转译;
grep [option]...PATTERN [filename]
grep的常见选项 -- option
-E 支持使用的扩展的正则表达式(ERE) (regexp)
-P 使用perl语言的正则表达式引擎进行搜索(每一种语言的正则表达式引擎都不相同,甚至sed grep awk使用的regexp引擎也不相同
-i 忽略大小
-v 进行反选
-o 仅仅输出匹配的内容(默认输出的是匹配到的行)
--color=auto 语法着色
-n 显示行号
PATTERN--正则表达式
作用:通过一些特殊字符,来表示一类字符内容,然后交给前面的命令来执行;如果使用特殊字符本身含义,就需要 进行转译;
回顾:文件通配符(globbing)
*?[][^]
1、字符匹配
. 任意一个字符 ?
[] 范围内的任意一个字符
[^]范围外任意一个字符
字符类:[:digit]数字[:alnum:]字母和数字[:alpha:]字母[:lower:][:upper:][;space:]空格[:punct:]
2、次数匹配
*匹配前面的字符0次到无数次
?匹配前面的字符0次到1次
+匹配前面的字符1次到无数次
{m}匹配前面的字符m次
{m,n}匹配前面的字符m到n次
{0,n}匹配前面的字符0次到n次
{m,}匹配前面的字符至少m次
. 任意一个字符 ?
[] 范围内的任意一个字符
[^]范围外任意一个字符
字符类:[:digit]数字[:alnum:]字母和数字[:alpha:]字母[:lower:][:upper:][;space:]空格[:punct:]
2、次数匹配
*匹配前面的字符0次到无数次
?匹配前面的字符0次到1次
+匹配前面的字符1次到无数次
{m}匹配前面的字符m次
{m,n}匹配前面的字符m到n次
{0,n}匹配前面的字符0次到n次
{m,}匹配前面的字符至少m次
3、位置锚定
^锚定行首
$锚定行尾
锚定词首和锚定词尾
>锚定词尾
<锚定词首
4、分组
()实例:(abc)* abcabcabc...
**分组特性:默认情况下,Linux系统会为分组指定变量,变量的表示形式 1 2 3...
示例:(ab+(xy)*),其中1 = ab+(xy)*,2=xy
abbbbxyxyxyabxy
if语句:
if条件语句的使用格式:
1、单分支语句
if 条件;then
执行语句
fi
2、双分支语句
if 条件;then
执行语句1
else
执行语句2
fi
3、多分支语句
if 条件;then
执行语句1
elif;then
执行语句2
elif;then
执行语句3
else
执行语句4
fi
if条件语句的使用格式:
1、单分支语句
if 条件;then
执行语句
fi
2、双分支语句
if 条件;then
执行语句1
else
执行语句2
fi
3、多分支语句
if 条件;then
执行语句1
elif;then
执行语句2
elif;then
执行语句3
else
执行语句4
fi
退出码:
exit
在某些条件判断下,如果不满足该条件,我们必须手动退出程序,否则后面的代码无法执行;
代码正确执行完成后,我们制定 exit 0 为正确退出码;
exit
在某些条件判断下,如果不满足该条件,我们必须手动退出程序,否则后面的代码无法执行;
代码正确执行完成后,我们制定 exit 0 为正确退出码;
1、判断/etc/inittab文件是否大于100行,如果大于,则显示”/etc/inittab is a big file.”否者显示”/etc/inittab is a small file.”
2、给定一个用户,来判断这个用户是什么用户,如果是管理员用户,则显示“该用户为管理员”,否则显示“该用户为普通用户”
3、判断某个文件是否存在
#!/bin/bash
# 判断文件是否存在
if [ $# -lt 1 ]; then
echo "At least one argument."
exit 1
fi
2、给定一个用户,来判断这个用户是什么用户,如果是管理员用户,则显示“该用户为管理员”,否则显示“该用户为普通用户”
3、判断某个文件是否存在
#!/bin/bash
# 判断文件是否存在
if [ $# -lt 1 ]; then
echo "At least one argument."
exit 1
fi
if [ -e $1 ];then
echo "存在"
else
echo "不存在"
if
echo "存在"
else
echo "不存在"
if
4、判断当前系统上是否有用户的默认shell程序是否为bash程序,如果有,就显示有多少个这类用户,否则就显示没有这类用户;【并且显示出那些用户是bash】
#!/bin/bash
# 判断用户的默认shell程序类型
declare -i sum=`grep "bin/bash$" /etc/passwd | wc -l`
#!/bin/bash
# 判断用户的默认shell程序类型
declare -i sum=`grep "bin/bash$" /etc/passwd | wc -l`
if grep "/bin/bash$" /etc/passwd &> /dev/null ; then
echo "存在 $sum 个用户,shell程序为/bin/bash"
grep "/bin/bash$" /etc/passwd | cut -d: -f1
exit 0
else
echo "没有这类用户"
exit 1
fi
5、写出一个脚本程序,给定一个文件,比如:/etc/inittab a、判断这个文件中是否有空白行? b、如果有,则显示其空白行的行号,否则显示没有空白行
^[[:space:]]*$
echo "存在 $sum 个用户,shell程序为/bin/bash"
grep "/bin/bash$" /etc/passwd | cut -d: -f1
exit 0
else
echo "没有这类用户"
exit 1
fi
5、写出一个脚本程序,给定一个文件,比如:/etc/inittab a、判断这个文件中是否有空白行? b、如果有,则显示其空白行的行号,否则显示没有空白行
^[[:space:]]*$
#!/bin/bash
#
B=`grep -n "^[[:space:]]*$" /etc/inittab | wc -l`
C=`grep -n "^[[:space:]]*$" /root/abc | cut -d: -f1`
if [ $B -eq 0 ] ; then
echo "没有空白行"
exit 1
else
echo "有空白行,空白行为 $C 行"
exit 0
fi
#
B=`grep -n "^[[:space:]]*$" /etc/inittab | wc -l`
C=`grep -n "^[[:space:]]*$" /root/abc | cut -d: -f1`
if [ $B -eq 0 ] ; then
echo "没有空白行"
exit 1
else
echo "有空白行,空白行为 $C 行"
exit 0
fi
6、写一个脚本程序,给定一个用户,判断其UID与GID是否一样,如果一样,就显示该用户为“good guy”,否则显示为“bad guy”
#!/bin/bash
#
1、for 做遍历 /etc/passwd
for i in $(cat /etc/passwd);do //sed可以完成;
2、判断每一行的UID和GID
if [ `cut -d: -f3 $i` = `cut -d: -f4 $i` ];then
echo "good guy"
exit 0
else
echo "bad guy"
exit 1
fi
done
#!/bin/bash
#
1、for 做遍历 /etc/passwd
for i in $(cat /etc/passwd);do //sed可以完成;
2、判断每一行的UID和GID
if [ `cut -d: -f3 $i` = `cut -d: -f4 $i` ];then
echo "good guy"
exit 0
else
echo "bad guy"
exit 1
fi
done
7、写一个脚本程序,给定一个用户,获取其密码警告期限($W);然后判断用户最近一次修改密码的时间距离今天是否已经小于警告期限;
/etc/passwd /etc/shadow /etc/group /etc/gshadow
用户(X) 密码 组 组密码
#!/bin/bash
#
8、判断命令历史中历史命令的总条目是否大于1000,如果大于,则显示“some command will gone”,否则显示OK
#!/bin/bash
#
S=`history | awk '{print $1}' | tail -1`
if [ $S -gt 1000 ];then
echo "some command will gone"
exit 0
else
echo "OK"
fi
/etc/passwd /etc/shadow /etc/group /etc/gshadow
用户(X) 密码 组 组密码
#!/bin/bash
#
8、判断命令历史中历史命令的总条目是否大于1000,如果大于,则显示“some command will gone”,否则显示OK
#!/bin/bash
#
S=`history | awk '{print $1}' | tail -1`
if [ $S -gt 1000 ];then
echo "some command will gone"
exit 0
else
echo "OK"
fi
9、给定一个文件,如果是普通文件,就显示出来,如果是目录文件,也显示出来,否则就显示“无法识别”
#!/bin/bash
#
# input()
read -t 5 -p ("请输入一个文件:") filename // -t 等待时间
echo # 默认用来换行
#!/bin/bash
#
# input()
read -t 5 -p ("请输入一个文件:") filename // -t 等待时间
echo # 默认用来换行
if [ -n $filename ];then
echo "eg. /etc/fstab"
exit 8
fi
echo "eg. /etc/fstab"
exit 8
fi
if [ -f $filename ]; then
echo "$filename 是一个普通文件"
exit 0
elif [ -d $filename ];then
echo "$filename 是一个目录文件"
exit 0
else
echo "无法识别"
exit 1
fi
echo "$filename 是一个普通文件"
exit 0
elif [ -d $filename ];then
echo "$filename 是一个目录文件"
exit 0
else
echo "无法识别"
exit 1
fi
-----------------------------------------------------
改成 case 语句;
10、写一个脚本,能接受一个参数(文件路径),判断这个参数如果是一个存在的文件就显示“ok”,否则显示“No such file"
#!/bin/bash
#
read -p "请输入一个文件路径:" filename
if [ -e $filename ];then
echo "OK"
else
echo "No such file"
fi
#!/bin/bash
#
read -p "请输入一个文件路径:" filename
if [ -e $filename ];then
echo "OK"
else
echo "No such file"
fi
11、写一个脚本,给脚本传递两个参数,显示两则之和和两者之积
#!/bin/bash
#
echo $[$1+$2]
echo $[$1*$2]
#!/bin/bash
#
echo $[$1+$2]
echo $[$1*$2]