Shell:Day04.笔记

grep与正则表达式:
1、grep程序
 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--正则表达式
  作用:通过一些特殊字符,来表示一类字符内容,然后交给前面的命令来执行;如果使用特殊字符本身含义,就需要 \ 进行转译;

  回顾:文件通配符(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次

  3、位置锚定
   ^锚定行首
   $锚定行尾
   \b锚定词首和锚定词尾
   \>锚定词尾
   <\锚定词首
  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
 退出码:
  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
 if [ -e $1 ];then
  echo "存在"
 else
  echo "不存在"
 if
4、判断当前系统上是否有用户的默认shell程序是否为bash程序,如果有,就显示有多少个这类用户,否则就显示没有这类用户;【并且显示出那些用户是bash】
 #!/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:]]*$
 #!/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    
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
 
 
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
 
9、给定一个文件,如果是普通文件,就显示出来,如果是目录文件,也显示出来,否则就显示“无法识别”
 #!/bin/bash
 #
 # input()
 read -t 5 -p ("请输入一个文件:") filename   // -t 等待时间
 echo  # 默认用来换行
 if [ -n $filename ];then
  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
 -----------------------------------------------------
 改成 case 语句;
10、写一个脚本,能接受一个参数(文件路径),判断这个参数如果是一个存在的文件就显示“ok”,否则显示“No such file"
 #!/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]

猜你喜欢

转载自www.cnblogs.com/why098/p/11353418.html