##1.计算1-100的和
sum=0
for i in `seq 1 100`;do
sum=$[$sum+$i]
done
echo $sum
##2.编写shell脚本,要求输入一个数字,然后计算出从1到输入数字的和,要求,如果输入的数字小于1,则重新输入,直到输入正确的数字为止
n=0
while [ $n -lt 1 ] ;do
read -p "请输入大于或者等于1的数字:" n
done
sum=0
for i in `seq 1 $n`;do
sum=$[$sum+$i]
done
echo $sum
##3.编写shell脚本,把/root/目录下的所有目录(只需要一级)拷贝到/tmp/目录下
for i in `ls ./demo`;do
echo $i
if [ -d $i ];then
echo "$i是文件"
cp -r ./demo/$i ./tmp
echo "cp复制"
fi
done
##4. 编写shell脚本,批量建立用户user_00, user_01, … ,user_100并且所有用户同属于users组;
groupadd users;
for i in `seq 0 9`;do
useradd -G users user_$i
done
for i in `seq 10 100`;do
useradd -G users user_$i
done
##5. 编写shell脚本,截取文件test.log中包含关键词’abc’的行中的第一列(假设分隔符为”:”),然后把截取的数字排序(假设第一列为数字),然后打印出重复次数超过10次的列;
awk -F ":" "$0~/abc/ {print $1}" test.log > data.txt
sort -n data.txt |uniq -c|sort -n > res.txt
awk '$1>10 {print $2}' res.txt
#uniq -c 检查文件并删除文件中重复出现的行,并在行首显示该行重复出现的次数。
补充uniq
命令的用法
##6. 编写shell脚本,判断输入的IP是否正确(IP的规则是,n1.n2.n3.n4,其中1<n1<255, 0<n2<255,="" 0<n3<255,="" 0<n4<255<="" span="">)。
???
## 7.批量重命名
for filename in `ls *.mp3`; do
mv $filename $(basename $filename .mp3).mp4
done
#实用场景,递归删除一个文件夹下指定后缀名的文件
#! /bin/bash
function deletefiles(){
if [ "${1##*.}" = "$2" ];then
echo "后缀名是 $2, 删除 $1"
rm -f $1
fi
}
function listfolder(){
if [ ! -d "$1" ] || [ "`ls -A $1`" = "" ]
then
echo "$1不存在或者是个空目录"
else
flists=`ls $1`
cd $1
for f in $flists
do
if test -d $f
then
listfolder $f $2
else
deletefiles $f $2
fi
done
cd ../
fi
}
dir=./demo
listfolder $dir txt mp3