文章目录
shell复习
1.如何获取一个文件每一行的第三个元素?
awk '{print $3}' 文件名
备注:awk支持按列输出,通过内置变量$1,$2,$3…可以单独显示任意列,默认列是以空格或者tab缩进为分隔符,也可以使用-F 选项指定其他分隔符。
2.shell函数能解决什么实际问题
定义函数的格式
function 函数名{
代码块
}
函数名() {
代码块
}
使用函数可以避免代码重复
使用函数可以将大的工程分隔为若干个小的功能模块,代码的可读性更高
3.使用awk统计httpd访问日志中每个客户端IP的出现次数
两种方式
awk '{ip[$1]++}END{for(i in ip) {print ip[i],i}}' /var/log/httpd/access_log
awk '{print $1}' /var/log/httpd/access_log |sort -rn | uniq -c
备注:定义数组,数组名称为ip,数字的下标为日志文件第一列(也就是客户端的IP地址),++的目的在于对客户端进行统计次数,可u段IP出现一次计数器就加一,END中的指令在堆区完文件之后执行,通过循环讲所有统计信息输出
4.那些方式可以将标准输出和错误输出重定向到文件?
命令 &> 文件名 #正确和错误都输出
命令 > 文件名1 2> 文件名2 #正确输出文件1,错误输出文件2
命令 > 文件名 2>&1 #正确的输出到文件,错误的输出到正确的 ,作用与第一个&>相同
#下面效果与上述差不多,结果为追加
命令 &>> 文件名 #正确和错误都追加到文件
命令 >> 文件名1 2>> 文件名2 #正确追加到文件1,错误追加到文件2
命令 >> 文件名 2>>&1 #正确的追加到到文件,错误的追加到正确的 ,作用与第一个&>>相同
5.正则表达式符号:*、+、?、[]、[^]、\{n\}分别代表什么含义
* 表示匹配前面的字符出现了任意次(包括0次)
+ 表示匹配前面的字符出现了至少一次(1次或者多次)
? 表示匹配前的字符出现了0次或者1次
[] 表示集合,匹配集合中的任意单个字符
[^]表示对集合取反
\{n\}表示精确匹配前面的字符出现了n次
6.shell中对变量字串进行截取的方式有哪些
echo ${变量名:开始位置:长度} #注意,起始位置从0开始
expr substr $变量名 开始位置 长度 #注意,起始位置从1开始
echo $变量名 | cut -b 开始位置-结束位置 #注意,起始位置从1开始
7.使用sed命令如何将文件中所有大写字母Q转换为小写字母q?
sed -i 's/Q/q/g' 文件名
8.执行如下命令会对test.txt文件产生什么样的影响
sed -i 's9\945\9\99\98\939g' test.txt
sed默认替换符为“/” ,当不是默认替换符时,s之后第一个字符就是替换符,所以在这题中9就是替换符,当替换的字符中有替换符,使用“\”进行转译,所以着道题答案就是,将test.txt文件中的94599替换为9893
9.编写脚本,用户输入密码,脚本判断密码是否正确,输入正确则提示正确,连续输入错误密码三次则警告
vim test.sh
#! /bin/bash
pass=123456
for i in {1..3}
do
read -p "请输入密码:" passwd
if [ $passwd == $pass ];then
echo "密码正确"
exit
fi
done
echo "警告:密码错误"
10.编写脚本,自动生成一个8位随机密码
#! /bin/bash
a=qwertyuiopasdfghjklzxcvbnmQWERTYUIOPASDFGHJKLZXCVBNM0123456789
for i in {1..8}
do
b=$[RANDOM%62]
c=${a:$b:1}
pass=$pass$c
done
echo $pass