linux 所有用户查询语句,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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值