shell编程、查找命令、压缩文件工具

shell编程、查找命令、压缩文件工具

 shell编程

一、条件测试

 1、判断某需求是否满足,需要由测试机制来实现。

   测试命令:

 ·test Expression

 ·[ EXPRESSION ]

 ·[[ EXPRESSION ]]

   需要注意的是:EXPRESSION前后必须有空白字符。&&代表and之意。||代表条件性OR

长格式的举例:

    $ test $A == $B && echo Strings are equal

2、数值测试

   -gt:是否大于

   -ge:是否大于等于

   -eq:是否等于

   -ne:是否不等于

   -lt:是否小于

   -le:是否小于等于

3、字符串测试

   ==:是否等于

   >:ascii码是否大于ascii

   <:是否小于

   !=:是否不等于

=~:左侧字符是否能够被右侧的PATTERN所匹配

    -z "STRING" :字符串是否为空,空为真,不空为假

    -n "STRING" :字符串是否不空,不空为真,空为假

     注意:用于字符串比较时的用到的操作数都应该使用引号

4、文件测试

   存在性测试

   -a FILE :同-e

   -e FILE:  文件存在性测试,存在为真,否则为假;

    存在性及类别测试

    -b FILE :是否存在且为块设备文件;

    -c FILE :是否存在且为字符设备文件;

    -d FILE :是否存在且为目录文件;

    -f FILE :是否存在且为普通文件;

    -h FILE -L FILE :存在且为符号链接文件;

    -p FILE :是否存在且为命名管道文件;

    -S FILE:是否存在且为套接字文件

5、文件权限测试

   文件权限测试:

   -r FILE :是否存在且可读

   -w FILE:  是否存在且可写

    -x FILE:  是否存在且可执行

   文件特殊权限测试:

    -g FILE :是否存在且拥有sgid 权限;

    -u FILE :是否存在且拥有suid 权限;

    -k FILE :是否存在且拥有sticky

6、文件大小测试:

    -s FILE:  是否存 在 且非空;

   文件是否打开:

    -t fd: fd 表示文件描述符是否已经打开且与某终端相关

    -N FILE :文件自动上一次被读取之后是否被修改过

    -O FILE :当前有效用户是否为文件属主

-G FILE :当前有效用户是否为文件属组

7、  双目测试:

      FILE1 -ef FILE2: FILE1 FILE2 是否指向同一个设

      备上的相同inode

      FILE1 -nt FILE2: FILE1 是否新于FILE2; ;

      FILE1 -ot FILE2: FILE1 是否旧于FILE2

8、组合测试条件

   第一种方式:

   COMMAND1 && COMMAND2  并且

   COMMAND1 || COMMAND2  或者

   ! COMMAND

   如:[ -e FILE ] && [ -r FILE ]

  第二种方式:

    EXPRESSION1 -a EXPRESSION2  并且

    EXPRESSION1 -o EXPRESSION2  或者

    ! EXPRESSION

必须使用测试命令进行;

9、使用read命令来接收输入

   使用read 来把输入值分配给一个或多个shell 变量:

   -p 指定要显示的提示

    -t TIMEOUT

     read 从标准输入中读取值,给每个单词分配一个变量

所有剩余单词都被分配给最后一个变量

举例:read  -p please input a number:“ FILE

二、流程控制

 1、条件选择if语句

  选择执行:

  注意: :if 语句可 嵌套

  单分支

if  判断条件:then

条件为真的分支代码

fi

  双分支

if  判断条件; then

条件为真的分支代码

else

条件为假的分支代码

fi

  多分支

if  CONDITION1 ; then

if-true

elif CONDITION2 ; then

if-ture

elif CONDITION3 ; then

if-ture

else

all-false

fi  

逐条 件进行判断,第一次遇为“真”条件时,执行其分支,

而后 结束整个if

举例:命令行输入: ]#if [ -r /etc/shadow ];then echo "the file is read "; fi

the file is read

 

2、条件判断:case 语句

case 用 变量引用 in

PAT1)

分支1

;;

PAT2)

分支2

;;

*)

默认分支

;;

esac

case 支持glob 风格的通配符:

*:  任意长度任意字符

?:  任意单个字符

[] :指定范围内的任意单个字符

a|b: a b

 

文件查找与压缩

 

 

1、locate命令

·查询系统上预建的文件索引数据库

     /var/lib/mlocate/mlocate.db

·依赖于事先构建的索引;

·索引的构建是在系统较为空闲时自动进行( 周期性任务) ;管理

员手动更新数据库(updatedb); ;

·索引构建过程需要遍历整个根文件系统,极消耗资源;

·工作特点:

查找速度快;

模糊查找;

非实时查找

搜索的是文件的全路径,不仅仅是文件名

可能只搜索用户具备读取和执行权限的目录

 locate的使用

locate KEYWORD

  有用的选项

-i 执行区分大小写的搜索

-n X 只列举前X 个匹配项目

 locate foo

• 搜索名称或路径中带有“foo ”的文件

 locate -r \.foo$

• 使用Regex 来搜索以“.foo

2、find命令

1find命令概述:实时查找工具,通过遍历指定路径完成文件查找;

工作特点:

查找速度略慢

精确查找

实时查找

可能只搜索用户具备读取和执行权限的目录

2find语法

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

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

查找条件:指定的查找标准,可以文件名、大小、类型、

权限等标准进行;默认为找出指定路径下的所有文件

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

3)查找条件

<1>根据文件名和inode 查找:

-name " 文件名称" :支持使用glob

*, ?, [], [^]

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

-inum n inode 号查找

-samefile name 相同inode 号的文件

-links n 链接数为n 的文件

举例:

 find / -name  “*.txt”记得需要加“”引号

<2>根据属主、属组查找:

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

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

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

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

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

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

<3>  根据文件类型查找:

-type TYPE:

f:  普通文件

d:  目录文件

l:  符号链接文件

s :套接字文件

b:  块设备文件

c:  字符设备文件

p:  管道文件

<4>  组合条件:

与:-a

或:-o

非:-not, !

德 德· 摩根 定律:

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

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

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

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

<5>  根据文件大小来查找:

-size [+|-]#UNIT

常用单位:k, M, G

#UNIT: (#-1, #] ,如:6k

-#UNIT [0,#-1],  如:-6k

+#UNIT (#, ), 如:+6k

<6>根据时间戳:

以“天”为单位;

-atime [+|-]#,

#: [#,#+1)

+#: [#+1, ]

-#: [0,#)

-mtime

-ctime

以“分钟”为单位:

-amin

-mmin

-cmin

<7>  根据权限查找:

-perm [/|-]MODE

MODE:  精确权限匹配

/MODE :任何一类(u,g,o) 对象的权限中只要能一位匹配

即 可 ,或关系,+  centos7 开始淘汰

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

0  表示不关注

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

•  只要当任意人有写权限时,find -perm +222 就会匹配

•  只有当每个人都有写权限时,find -perm -222 才会匹配

•  只有当其它人(other )有写权限时,find -perm -002才 才

会匹配

<8> 处理动作

-print :默认的处理动作,显示至屏幕;

 -ls :类似于对查找到的文件执行“ls -l” 命令

 -delete :删除查找到的文件;

 -fls file :查找到的所有文件的长格式信息保存至指定文件中

 -ok COMMAND {} \;  对查找到的每个文件执行由

COMMAND 指定的命令;

对于每个文件执行命令之前,都会交互式要求用户确认

 -exec COMMAND {} \;  对查找到的每个文件执行由

COMMAND 指定的命令

 {}:  用于引用查找到的文件名称自身

 find 传递查找到的文件至后面指定的命令时,查找到所有符合

条件的文件一次性传递给后面的命令

  有些命令不能接受过多参数,此时命令执行可能会失败,下

面方式可规避此问题

find | xargs COMMAND

 

压缩文件工具

一、comperss命令(不常用)

 compress [-dfvcVr] [-b maxbits] [file …]

-d:  解压缩,相当于

-c:  结果输出至标准输出, 不删除原文件

-v:  显示详情

 uncompress 解压缩

 zcat file.Z >file

二、gizp命令

 gzip [OPTION]… FILE …

-d:  解压缩,相当于gunzip

-c:  将压缩或解压缩的结果输出至标准输出

-# 1-9 ,指定压缩比,值越大压缩比越大

 zcat :不显式解压缩的前提下查看文本文件内容

  实例:

    gzip -c messages >messages.gz

    gzip -c -d messages.gz > messages

    zcat messages.gz > messages

三、bizp2命令

 bzip2 [OPTION]… FILE …

   -k: keep,  保留原文件

   -d :解压缩

   -# 1-9 ,压缩比,默认为6

 bzcat :不显式解压缩的前提下查看文本文件内容;

四、xz命令

 xz [OPTION]… FILE …

   -k: keep,  保留原文件;

   -d :解压缩

   -# 1-9 ,压缩比,默认为6; ;

 xzcat:  不显式解压缩的前提下查看文本文件内容

     

 

                  作业

1 、写一个脚本/root/bin/createuser.sh ,实现如下功能:

使用一个用户名做为参数,如果指定参数的用户存在,就显

示其存在,否则添加之;显示添加的用户的id 号等信息.

答:

图片1.png

 

2 、写一个脚本/root/bin/yesorno.sh ,提示用户输入yes或 或

no, 并判断用户输入的是yes 还是no, 或是其它信息

答:

图片2.png 

3 、写一个脚本/root/bin/filetype.sh, 判断用户输入文件路

径,显示其文件类型(普通,目录,链接,其它文件类型)

答:

图片3.png

4 、写一个脚本/root/bin/checkint.sh, 判断用户输入的参数

是否为正整数

答:判断一个数是否为正整数,我想到了使用grep去匹配数字

图片4.png 

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

答:

图片5.png 

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

答:

图片6.png 

7 、查找/var 目录下最近一周内其内容修改过,同时属主不为

root ,也不是postfix 的文件。

答: 图片7.png8 、查找当前系统上没有属主或属组,且最近一个周内曾被访

问过的文件。

答:

图片8.png

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

答:

图片9.png 

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

答:

图片10.png 

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

答:全部都有执行权限,进行取反即可。

图片11.png

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

用户有写权限的文件   

答:注意/etc/init.d后需要加/

# find  /etc/init.d/    -perm  -111 -a -perm  /002  -ls

# find  /etc/init.d/    -perm  -113  -ls

          

 

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

(0)
178babyhanggege178babyhanggege
上一篇 2016-08-15
下一篇 2016-08-15

相关推荐

  • shell脚本编程练习

    1、写一个脚本,使用ping命令探测172.16.250.1-172.16.250.254之间的所有主机的在线状态 在线的主机使用绿色显示 不在线的主使用红色显示 #!/bin/bash # for i in {1..254};do if ping -c 6 -w 1 192.168.1.$i &> /dev/null;then echo -e…

    2017-11-15
  • find命令使用练习

    1、  查找/var目录下属主为root,且属组为mail的所有文件   2、  查找/var目录下不属于root、lp、gdm的所有文件   3、  查找/var目录下最近一周内其内容修改过,同时属主不为root,也不是postfix的文件   4、  查找当前系统上没有属主或属组,且最…

    Linux干货 2016-08-15
  • Linux基础之shell脚本编程(二)

    1、写一个脚本,完成以下功能    (1) 假设某目录(/etc/rc.d/rc3.d/)下分别有K开头的文件和S开头的文件若干;    (2) 显示所有以K开头的文件的文件名,并且给其附加一个stop字符串;    (3) 显示所有以S开头的文件的文件名,并且给其附加一个start字符串; &nb…

    Linux干货 2016-11-17
  • N26-第六周

    请详细总结vim编辑器的使用 vim 模式化的编辑器 vim的三种模式:1.编辑模式(命令模式)                          2.输入模式          …

    Linux干货 2017-03-13
  • 文件的权限详解(二)ACL篇

    文件的权限详解(二)ACL篇 ACL访问控制列表作用: 1、 ACL:Access Control List,实现灵活的权限管理2、 除了文件的所有者,所属组和其它人,可以对更多的用户设置权限3、 CentOS7.0默认创建的xfs和ext4文件系统有ACL功能。4、 CentOS7.X之前版本,默认手工创建的ext4文件系统无ACL功能。需手动增加: tu…

    Linux干货 2016-08-05
  • 通配符、正则表达式小计

    基本通配符:    *: 匹配任意长度的任意字符;    ?: 匹配任意的单个字符;    []: 匹配指定范围内的任意单个字符;    [^]: 匹配非指定范围内的任意单个字符;   简单示例:   &nbs…

    Linux干货 2017-03-16

评论列表(1条)

  • 马哥教育
    马哥教育 2016-08-19 10:24

    文章写的很用心,对当天所学的东西有了一个完整的人是和梳理,不过linux学习最重要是实际操作,希望下来多加练习,掌握当天所学的东西。