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)
上一篇 2016-08-16 13:59
下一篇 2016-08-16 13:59

相关推荐

  • iptables简单概念..

    iptables: 包过滤型的防火墙 Firewall:防火墙,隔离工具;工作于主机或网络边缘,对于进出本主机或本网络的报文根据事先定义的检查规则作匹配检测,对于能够被规则匹配到的报文作出相应处理的组件;    主机防火墙     网络防火墙   &…

    Linux干货 2017-06-19
  • 2班jackcui20160802作业

    1、每日课堂笔记总结 2、预习 3、每日课堂pdf练习 4、在/data/testdir里创建的新文件自动属于g1组,组g2的成员如:alice能对这些新文件有读写权限,组g3的成员如:tom只能对新文件有读权限,其它用户(不属于g1,g2,g3)不能访问这个文件夹。 [root@centos7 /]# groupadd g1 [root@centos7 /…

    Linux干货 2016-08-05
  • Linux-Centos7编译内核

    编译内核     前提:         (1)准备好开发环境         (2) 获取目标主机上硬件设备的相关信息         (3) 获取目标主机系统功能的相关信息       …

    2017-07-16
  • 马哥教育网络班22期+第二周课程练习

    一、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示? cp命令:copy,有2类复制方法  1、单源复制:如果DEST不存在:则实现创建此文件,并复制源文件的数据流至DEST中;     如果DEST存在:如果DEST是非目录文件,则覆盖目标文件;如果DEST是目录文件,则先DEST目录下创建一个与源文件…

    Linux干货 2016-08-22
  • 马哥教育网络班19期+第八周课程练习

    1、请描述网桥、集线器、二层交换机、三层交换机、路由器的功能、使用场景与区别。    主要功能:    网桥是一个局域网与另一个局域网之间建立连接的桥梁,属于数据链路层的一种设备。    集线器是可以将一些机器连接起来组成一个局域网的设备。   &n…

    Linux干货 2016-06-26
  • 马哥教育网络班20期第3周课程练习

    答: 1、 [root@totooco ~]# who | cut -c1-9 | sort -u 2、 [totooco@totooco ~]$ who | cut -c1-9 | head -1 3、 [root@totooco ~]# cat /etc/passwd | cut -d: -f7 | grep -v /sbin/nologin | sor…

    Linux干货 2016-06-23

评论列表(1条)

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

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