shell中的if else语句与文件查找find浅析

shell中的if else语句与文件查找find浅析


   上篇文章中我们讲述了shell脚本编程的初步入门,其中讲到了shell编程中的顺序执行,顺序执行时一种简单的小脚本,如果在编辑脚本的时候遇到要做出条件判断执行的时候要怎么办呢?我们学习过if之后你会发现这会很简单。if 语句通过关系运算符判断表达式的真假来决定执行哪个分支。

Shell 有三种 if … else 语句:

   if … fi 语句;

   if … else … fi 语句;

   if … elif … else … fi 语句。

1) if … else 语句

   if … else 语句的语法:

if [ expression ]
then
   Statement(s) to be executed if expression is true
fi

如果 expression 返回 true,then 后边的语句将会被执行;如果返回 false,不会执行任何语句。

最后必须以 fi 来结尾闭合 if,fi 就是 if 倒过来拼写,后面也会遇见。

注意:expression 和方括号([ ])之间必须有空格,否则会有语法错误。

示例:

[root@centos7 ~]# ./test.sh 
a is not equal to b
[root@centos7 ~]# cat test.sh 
#!/bin/sh
a=10
b=20
if [ $a == $b ]
then
   echo "a is equal to b"
fi
if [ $a != $b ]
then
   echo "a is not equal to b"
fi

2) if … else … fi 语句

   if … else … fi 语句的语法:

if [ expression ]
then
   Statement(s) to be executed if expression is true
else
   Statement(s) to be executed if expression is not true
fi

如果 expression 返回 true,那么 then 后边的语句将会被执行;否则,执行 else 后边的语句。

示例:

[root@centos7 ~]# ./test1.sh 
a is not equal to b
[root@centos7 ~]# cat test1.sh 
#!/bin/sh
a=10
b=20
if [ $a == $b ]
then
   echo "a is equal to b"
else
   echo "a is not equal to b"
fi

3) if … elif … fi 语句

   if … elif … fi 语句可以对多个条件进行判断,语法为:

if [ expression 1 ]
then
   Statement(s) to be executed if expression 1 is true
elif [ expression 2 ]
then
   Statement(s) to be executed if expression 2 is true
elif [ expression 3 ]
then
   Statement(s) to be executed if expression 3 is true
else
   Statement(s) to be executed if no expression is true
fi

哪一个 expression 的值为 true,就执行哪个 expression 后面的语句;如果都为 false,那么不执行任何语句。

示例:

[root@centos7 ~]# cat test2.sh 
#!/bin/sh
a=10
b=20
if [ $a == $b ]
then
   echo "a is equal to b"
elif [ $a -gt $b ]
then
   echo "a is greater than b"
elif [ $a -lt $b ]
then
   echo "a is less than b"
else
   echo "None of the condition met"
fi
[root@centos7 ~]# chmod +x test2.sh 
[root@centos7 ~]# ./test2.sh 
a is less than b

read:

在脚本编程中使用read命令来接受输入,read从标准输入中读取值,给每个单词分配一个变量,使用read来把输入值分配给一个或多个shell变量

   -p 指定要显示的提示

   -t TIMEOUT

   read -p “Enter a filename: “ FILE

示例:

[root@centos7 bin]# cat creatuser.sh 
#!/bin/bash
read -p "请出入一个用户名:" username
if id $username &> /dev/null; then
     echo "用户$username 存在"
     getent passwd $username
else 
     echo "用户不存在"
     echo "创建$username 用户"
     useradd $username 
     echo "用户$username 创建成功"
     id $username
fi
[root@centos7 bin]# ./creatuser.sh 
请出入一个用户名:zanghl
用户不存在
创建zanghl 用户
用户zanghl 创建成功
uid=1003(zanghl) gid=1003(zanghl) groups=1003(zanghl)

这里运行脚本后显示出:“请出入一个用户名:” 用户手动输入一个用户名。

case esac语句:

case 语句匹配一个值或一个模式,如果匹配成功,执行相匹配的命令。case语句格式如下:

case 值 in
模式1)
    command1
    command2
    command3
    ;;
模式2)
    command1
    command2
    command3
    ;;
*)
    command1
    command2
    command3
    ;;
esac

case工作方式如上所示。取值后面必须为关键字in,每一模式必须以右括号结束。取值可以为变量或常数。匹配发现取值符合某一模式后,其间所有命令开始执行直至 ;;。

[root@centos7 bin]# cat yesorno.sh 
#!/bin/bash
read -p "请输入 yes or no:" yn
case $yn in
[yY][eE][sS]|[yY])
echo "yes is write"
;;
[nN][oO]|[nN])
echo "no is write"
;;
*)
echo "input error"
;;
esac
[root@centos7 bin]# ./yesorno.sh
请输入 yes or no:yEs
yes is write
[root@centos7 bin]# ./yesorno.sh
请输入 yes or no:n
no is write

find:

   每一种操作系统都有许多的文件组成,对于linux这样“一切皆文件”的操作系统来说更是如此,大家应该都能很轻松使用windows下的文件查找功能,但是对linux这一功能可能并不是很熟悉,linux不像windows那样有固定的文件名后缀,并且因为linux阵营下百家争鸣的特性,一个相同的文件在不同的发行版,可能会有不同,所以如果你能牢牢掌握find命令的使用,你在摸索linux的道路上将会顺利很多。同时你会发现linux下文件查找功能其实很简单,而且要比windows下查找功能强大很多很多。

语法:

   find [OPTION]… [查找路径] [查找条件] [处理动作]

      查找路径:指定具体目标路径;默认为当前目录

      查找条件:指定的查找标准,可以文件名、大小、类型、权限等标准进行;默认为找出指定路径下的所有文件

      处理动作:对符合条件的文件做操作,默认输出至屏幕

根据文件名和inode查找:

     -name "文件名称":支持使用glob *, ?, [], [^]

     -iname "文件名称":不区分字母大小写

     -inum n  按inode号查找

     -samefile name 相同inode号的文件

     -links n 链接数为n的文件

     -regex "PATTERN":以PATTERN匹配整个文件路径字 符串,而不仅仅是文件名称

根据属主、属组查找:

     -user USERNAME:查找属主为指定用户(UID)的文件

     -group GRPNAME: 查找属组为指定组(GID)的文件

     -uid UserID:查找属主为指定的UID号的文件

     -gid GroupID:查找属组为指定的GID号的文件

     -nouser:查找没有属主的文件

     -nogroup:查找没有属组的文件

组合条件:

     与:-a

     或:-o

     非:-not, !

德·摩根定律:

    非(P 且 Q) = (非 P) 或 (非 Q)

    非(P 或 Q) = (非 P) 且 (非 Q)

    !A -a !B = !(A -o B)

    !A -o !B = !(A -a B)

查找条件:

    -perm [/|-]MODE

       MODE: 精确权限匹配

       /MODE:任何一类(u,g,o)对象的权限中只要能一位匹配即可,或关系,+ 从centos7开始淘

       -MODE:每一类对象都必须同时拥有指定权限,与关系 0 表示不关注

       find -perm 755 会匹配权限模式恰好是755的文件

下面我们看一下下面这些示例:

这些示例能带给你对find的深刻理解

1、查找/var目录下属主为root,且属组为mail的所有文件

   find /var -user root -group mail

2、查找/var目录下不属于root、lp、gdm的所有文件

   find /var -not \( -user root -o -user lp -o -user gdm \) -ls

   find /var -not -user root -not -user lp -not -user gdm

这里的两个命令是一样的,根据德·摩根定律:非(P 或 Q) = (非 P) 且 (非 Q);

第二行的命令 -not -user root 与后面的 -not -user lp 中间连接的是 -a 只是默认没有写而已;

3、查找/var目录下最近一周内其内容修改过,同时属主不为 root,也不是postfix的文件

   find /var -mtime -7 -a -not \( -user root -o -user postfix \)

4、查找当前系统上没有属主或属组,且最近一个周内曾被访 问过的文件

   find / \( -nouser -o -nogroup \) -a -atime -7 

5、查找/etc目录下大于1M且类型为普通文件的所有文件

   find /etc -size +1M -a -type f

6、查找/etc目录下所有用户都没有写权限的文件

   find /etc ! -perm /222 -ls

7、查找/etc目录下至少有一类用户没有执行权限的文件

   find /etc ! -perm -111

8、查找/etc/init.d目录下,所有用户都有执行权限,且其它 用户有写权限的文件

   find /etc/init.d/ -perm -111 -perm /002

原创文章,作者:zanghonglei,如若转载,请注明出处:http://www.178linux.com/36341

(5)
zanghongleizanghonglei
上一篇 2016-08-16
下一篇 2016-08-16

相关推荐

  • Homework Week-9 bash脚本之顺序、选择、循环

    1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别这两类用户的个数;通过字符串比较来实现; #!/bin/bash #Elephant echo "nologin users:" user1=$(cat /etc/passwd&n…

    Linux干货 2016-10-17
  • linux作业管理

    作业管理 kill kill命令:     向进程发送控制信号,以实现对进程管理     显示当前系统可用信号:kill -l     常用信号:man 7 signal    &…

    Linux干货 2016-09-09
  • NFS的应用实例

    实验目的:通过NFS实现共享 实验要求:实验环境下防火墙以及selinux都是要关闭的!!! 实验环境:三台虚拟机,以及相关安装程序 实验过程: 设置服务端centos 6-1 [root@centos6 ~]# yum install mysql-servernfs-utils httpd [root@centos6 ~]# service mysqld …

    2017-05-03
  • Linux基础之加密通讯过程详解

    加密通讯过程详解 第一阶段 客户端->服务器端 向服务器声明自己的加密通讯协议版本,ssl或者tls 支持的加密算法 支持的压缩算法 第二阶段 服务器端->客户端 向客户端确认使用的加密通讯协议版本 确认的加密方法 确认压缩方法 服务器端证书 第三阶段 客户端->服务器端 客户端验证服务器端证书 发证机构 证书完整性 证书持有者 证书有效期…

    2017-09-16
  • Linux常用命令

    马哥教育网络班22期第四周课程练习 linux常用命令介绍(2) linux权限及命令组合使用示例 1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 ~]# cp -r /etc/skel /home/tuser1 &amp…

    Linux干货 2016-09-19

评论列表(1条)

  • 马哥教育
    马哥教育 2016-08-18 17:08

    结构框架清晰,层次分明,对当天学到的东西,总结的很详细,详略得当,可以把操作的执行结果放上来,这样会更好哦。