使用read 来把输入值分配给一个或多个shell 变量:
-p 指定要显示的提示
-t TIMEOUT
read 从标准输入中读取值,给每个单词分配一个变量
所有剩余单词都被分配给最后一个变量
read -p “Enter a filename: “ FILE
条件选择if语句 多分支
if CONDITION1 ; then
if-true
elif CONDITION2 ; then
if-ture
elif CONDITION3 ; then
if-ture
…
else
all-false
fi
逐条 件进行判断,第一次遇为“真”条件时,执行其分支,而后结束整个if
条件判断:case
case 用 变量引用 in
PAT1)
分支1
;;
PAT2)
分支2
;;
…
*)
默认分支
;;
esac
1.写一个脚本/root/bin/createuser.sh ,实现如下功能:使用一个用户名做为参数,如果指定参数的用户存在,就显示其存在,否则添加之;显示添加的用户的id
#!/bin/bash
read -p "please input a username: " user
id $user &>/dev/null
if [ $? -eq 0 ];then
echo "$user is exists"
else
useradd $user
echo "$user already created "
id $user
fi
注意:红色的地方不能带$号
2.写一个脚本/root/bin/yesorno.sh ,提示用户输入yes或no, 并判断用户输入的是yes 还是no
#!/bin/bash
read -p "Please input yes/no: " yesorno
case $yesorno in
[Yy][Ee][Ss]|[Yy])
echo yes
;;
[Nn][Oo]|[Nn])
echo no
;;
*)
echo other
;;
esac
3.写一个脚本/root/bin/filetype.sh, 判断用户输入文件路径,显示其文件类型(普通,目录,链接,其它文件类型)
#!/bin/bash
read -p "Input a file path: " file
file $file
if [ -h $file ];then
echo "$file is a symbolic link"
elif [ -f $file ];then
echo "$file is a common file"
elif [ -d $file ];then
echo "$file is a directory"
elif [ -p $file ];then
echo "$file is a pipe file"
elif [ -S $file ];then
echo "$file is a socket file"
elif [ -b $file ];then
echo "$file is a block file"
else
echo "please enter a correct file"
fi
4. 写一个脚本/root/bin/checkint.sh, 判断用户输入的参数是否为正整数
[root@localhost 0815]# vim checkint.sh
#!/bin/bash
read -p "please input a number: " number
[ -z $number ] && echo echo "you must input a number " && exit
echo $number|egrep -q '^[-[:digit:]]*$'
if [ $? -eq 0 ];then
if [ $number -gt 0 ];then
echo "$number is a positive number"
elif [ $number -eq 0 ];then
echo "Input is zero"
else
echo "$number is a negative number"
fi
else
echo Input is not a number!
fi
locate命令
快速、模糊、非实时查询,搜索未必精确,其依赖文件索引数据库/var/lib/mlocate/mlocate.db
linux有内容变动时,执行updatedb命令手动更新数据库,经实验加-v参数观察/tmp目录不在更新范围,因此/tmp内的文件无法被搜到,可采用find命令
locate常用选项:
-i:忽略大小写
-r:正则匹配,例:locate -r '\.exe$' // 搜索以.exe结尾的文件
find命令
find [option] [path] [conditon] [action]
根据文件名和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: 查找没有属组的文件
根据文件类型查找:
-type TYPE:
f: 普通文件
d: 目录文件
l: 符号链接文件
s: 套接字文件
b: 块设备文件
c: 字符设备文件
p: 管道文件
组合条件:
与:-a
或:-o
非:-not, !
德·摩根 定律:
非(P 且 Q) = (非 P) 或 (非 Q)
非(P 或 Q) = (非 P) 且 (非 Q)
!A -a !B = !(A -o B)
!A -o !B = !(A -a B)
记忆:非运算进出括号 -a与-o互换
实例
find / -user wang –o –uid 33213
找出/tmp 目录下,属主不是root ,且文件名不是fstab
find /tmp -not \( -user root -o -name 'fstab' \) 等价于
find /tmp \( -not -user root -a -not -name 'fstab' \)
注意: \( …… \) 格式,中间的空格不能省
排除目录
例: find /usr/local/tomcat/ -path '/usr/local/tomcat/conf' -a -prune -o -name *.xml –print //排除conf目录
根据文件大小来查找:
-size [+|-]#UNIT
常用单位:k, M, G
#UNIT: (#-1, #] ,如:6k 范围为5k~6k
-#UNIT :[0,#-1], 如:-6k 范围为0~5k
+#UNIT :(#, ∞ ), 如:+6k 范围为6k~∞
根据时间戳:
以“天”为单位;
-atime [+|-]#,
#: [#,#+1)
+#: [#+1,∞]
-#: [0,#)
-mtime
-ctime
以“分钟”为单位:
-amin
-mmin
-cmin
根据权限查找:
-perm [/|-]MODE
MODE: 精确权限匹配
/MODE :任何一类(u,g,o) 对象的权限中只要能一位匹配即可 ,或关系
-MODE :每一类对象都必须同时拥有指定权限,与关系
0 表示不关注
find -perm 755 会匹配权限模式恰好是755 的文件
只要当任意人有写权限时,find -perm +222 就会匹配
只有当每个人都有写权限时,find -perm -222 才会匹配
只有当other有写权限时,find -perm -002才会匹配
记忆:"与"是求交集,结果少,用减号(–);"或"是求并集,结果多,用正斜线(/)
处理动作
-print :默认的处理动作,显示至屏幕;
-ls :类似于对查找到的文件执行“ls -l” 命令
-delete :删除查找到的文件;
-fls file :查找到的所有文件的长格式信息保存至指定文件中,也开用>,重定向
-ok COMMAND {} \; 对查找到的每个文件执行由
COMMAND 指定的命令;
对于每个文件执行命令之前,都会交互式要求用户确认
实验得-ok rm {} \; 可以交互式删除文件
-ok delete {} \; 会报文件目录不存在
-delete 无提示直接删除
-exec COMMAND {} \; 对查找到的每个文件执行由COMMAND 指定的命令
{}: 用于引用查找到的文件名称自身
find 传递查找到的文件至后面指定的命令时,查找到所有符合条件的文件一次性传递给后面的命令
有些命令不能接受过多参数,此时命令执行可能会失败,下面方式可规避此问题
find | xargs COMMAND
实例:
find /root/shellscripts/ -type f -perm 644 -name *.sh -exec chmod 755 {} \;
//找到sh文件并添加执行权限
find -name *.xml -exec cp {} {}.org \; //配置文件做备份
find /tmp -ctime +3 -user root -ok rm {} \; //删除root存在时间超过3天以上的临时文件
find ~ -perm -002 -exec chmod o-w {} \;
实战:
1.查找/var 目录下属主为root ,且属组为mail 的所有文件
find /var -user root -group mail
2.查找/var 目录下不属于root.lp.的所有文件
find /var -not -user root -not -user lp
3.查找/var 目录下最近一周内其内容修改过,同时属主不为root ,也不是postfix 的文件
find /var -not \( -user root -o -user postfix \) -mtime -7
4.查找当前系统上没有属主或属组,且最近一个周内曾被访问过的文件
find / \( -nouser -o -nogroup -atime -7 \) -ls
5.查找/etc 目录下大于1M 且类型为普通文件的所有文件
find /etc -size +1M -type f
6.查找/etc 目录下所有用户都没有写权限的文件
find /etc/ -not -perm /222
7.查找/etc 目录下至少有一类用户没有执行权限的文件
find /etc/ -not -perm /111
8.查找/etc/init.d 目录下,所有用户都有执行权限,且其它用户有写权限的文件
find /etc/ -perm -111 -perm /002
原创文章,作者:victorycommander,如若转载,请注明出处:http://www.178linux.com/36723
评论列表(1条)
文章写的很认真,对细节方面有了一些明显的标识,通过实践操作将自己遇到的问题记录下来写成博客是个很好的习惯。