shell脚本for循环小练习

简介: shell脚本for循环小练习

目录


第一题


第二题


第三题


第四题


第五题


第六题


第七题


第八题


第一题



计算从1到100所有整数的和


#!/bin/bash
#计算从1到100所有整数的和
for i in {1..100}
do
        let sum+=$i
        #sum=$[$sum +$i]
done
echo "1到100所有整数的和为:$sum"


循环里面一定不能写成sum+=$i,这是字符串的追加 ,我们要实现的是循环相加


image.png


第二题



提示用户输入一个小于100的整数,并计算从1到该数之间所有整数的和


#!/bin/bash
#提示用户输入一个小于100的整数,并计算从1到该数之间所有整数的和
read -p "请输入一个小于100的整数:" num
for ((i=0;i<=$num ;i++))
#for i in $(seq 1 $num)
do 
  #sum=$[$sum+$i]
  let sum+=$i
done
echo "$num 以内的求和:$sum"

image.png


第三题



求从1到100所有整数的偶数和、奇数和


法一:


#!/bin/bash
#求从1到100所有整数的偶数和、奇数和
for i in $(seq 1 2 100)
do
        #sum=$[sum+i]
        let sum1+=$i
done
echo "100以内的奇数和:$sum1"
for i in $(seq 0 2 100)
do
        #sum=$[sum+i]
        let sum2+=$i
done
echo "100以内的偶数和:$sum2"


法二:


#!/bin/bash
#求从1到100所有整数的偶数和、奇数和
for i in $(seq 1 100)
do
        a=$[i % 2]
        if [ $a -eq 0 ]
        then
            let sum1+=$i
        #取余等于0是偶数
        else
            let sum2+=$i
        #取余等于1是奇数
        fi
done
echo "100以内的奇数和:$sum2"
echo "100以内的偶数和:$sum1"

image.png


第四题



用户名存放在users.txt文件中,每行一个,判断文件里的用户是否存在,若该用户存在,输出提示该用户已存在; 若该用户不存在,提示用户输入密码,建立用户并设立其密码


#!/bin/bash
#用户名存放在users.txt文件中,每行一个,判断文件里的用户是否存在,若该用户存>在,输出提示该用户已存在;若该用户不存在,提示用户输入密码,建立用户并设立其>密码
for USER in $(cat /data/users.txt)
do
        useradd $USER &> /dev/null
        if [ $? -ne 0 ]
        then
                echo "$USER 用户已经存在"
        else
                passwd $USER
                #echo "000000" | passwd --stdin $USER &> /dev/null
                echo "$USER 创建成功,并设置了密码" 
        fi
done


加一个功能:若用户存在但没设置密码,提醒用户设置密码


#!/bin/bash
#若用户存在但没设置密码,提醒用户设置密码
for USER in $(cat /data/users.txt)
do
#可以用su、id、passwd第一列判断用户是否存在
        cat /etc/passwd | awk -F: '{print $1}'|grep "$USER" &>/dev/null
#查看passwd文件,以冒号为分割,打印第一列,过滤下有没有用户已经存在
        if [ $? -eq 0 ]
        then
                echo "$USER 用户已经存在"
                res=$(cat /etc/shadow |grep "$USER" |awk -F: '{print $2}')
#根据shadow文件判断该用户是否有密码
                if [ "$res" = '!!' -o "$res" = '*' ]
#感叹号会被双引号识别为特殊字符,所以我们用单引号
                then
                        echo "$USER 没有设置密码"
                        read -p "请输入密码:" passwd
                        echo $passwd |passwd --stdin $USER
                fi
        else
                echo "用户不存在,正在创建$USER 用户..."
                useradd $USER
                read -p "请设置用户的密码:" passwd1
                read -p "请再次设置用户的密码:" passwd2
                if [ "$passwd1" = "$passwd2" ]
                then
                        echo $passwd1 |passwd --stdin $USER
                else
                        echo "密码设置不一致"
                fi
        fi
done

image.png


第五题



检测指定范围主机是否通信,并将通信的主机ip输出到文件host_ip中


#!/bin/bash
#检测指定范围主机是否通信,并将通信的主机ip输出到文件host_ip中
for host in {1..5}
do
        ping -c 3 -i 0.5 -w 2 192.168.109.$host &> /dev/null
#-c ping的次数
#-i 间隔时间
#-w 等待时间
#/dev/null 垃圾桶
        if [ $? -eq 0 ]
        then
                echo "192.168.109.$host is online" >> /data/host_ip
        fi
done


第六题

用户输入密码,脚本判断密码是否正确,正确密码为123456,输入正确提示正确信息,连续输错3次则报警


#!/bin/bash
#用户输入密码,脚本判断密码是否正确,正确密码为123456,输入正确提示正确信息,
连续输错3次则报警
for i in {1..3}
do
        read -p "请输入密码:" num
        if [ $num != "123456" ]
        then
                echo "密码错误,请重新输入!"
        else
                echo "密码正确!"
                break
        fi
        if [ $i -eq 3 ]
        then
        echo "告警,密码输错三次!"
        fi
done

image.png


第七题



编写能够自动生成一个6位随机密码的脚本


#!/bin/bash
#随机生成6位随机密码
#定义密码取值范围
String="abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789"
#循环8次
for i in {1..6}
do
        #每次循环随机获取0到字符串长度-1的下标值
        num=$[RANDOM % ${#String}]
        #进行字符串截取
        var=${String:num:1}
        #每次追加生成密码
        passwd+=$var
done
echo "本次生成的随机密码为:$passwd"

image.png


第八题



使用循环语句将一个 0到255 之间的十进制数转换成二进制数


法一:使用内置函数,此方法不能输出8位


#!/bin/bash
#使用循环语句将一个 0到255 之间的十进制数转换成二进制数,使用内置函数
for ((a=0;a<=255;a++))
do
        b=$(echo "obase=2;$a"|bc)
        echo " $a十进制数转换成二进制数为: $b"
done


法二:减法转换


#!/bin/bash
read -p "请输入一个0-255之间的整数:" num
for i in {128,64,32,16,8,4,2,1}
#i的取值范围
do
    a=$[num - i]
#a用来确定是否可以num减相应的i
    if [ $a -lt 0 ]
#a小于0说明不能减
    then
        echo -n 0 
#-n代表不换行输出,输出0
    else
        echo -n 1
        num=$[num - i]
#可以减输出1
    fi
done
echo ""
#换行

image.png


1    1    1    1  1  1  1  1


128 64  32 16  8  4  2  1


法三:


#!/bin/bash
read -p "请输入一个0-255之间的整数:" num
for i in {1..8}
do
    var=$[num % 2]
    sum=$var$sum
#字符串追加
    num=$[num / 2]
#自除2
done
echo $sum

image.png

目录
打赏
0
0
0
0
14
分享
相关文章
|
3月前
|
一个用于添加/删除定时任务的shell脚本
一个用于添加/删除定时任务的shell脚本
129 1
6种方法打造出色的Shell脚本
6种方法打造出色的Shell脚本
78 2
6种方法打造出色的Shell脚本
|
2月前
|
Shell脚本要点和难点以及具体应用和优缺点介绍
Shell脚本在系统管理和自动化任务中扮演着重要角色。尽管存在调试困难、可读性差等问题,但其简洁高效、易于学习和强大的功能使其在许多场景中不可或缺。通过掌握Shell脚本的基本语法、常用命令和函数,并了解其优缺点,开发者可以编写出高效的脚本来完成各种任务,提高工作效率。希望本文能为您在Shell脚本编写和应用中提供有价值的参考和指导。
91 1
ubuntu/debian shell 脚本自动配置 gitea git 仓库
这是一个自动配置 Gitea Git 仓库的 Shell 脚本,支持 Ubuntu 20+ 和 Debian 12+ 系统。脚本会创建必要的目录、下载并安装 Gitea,创建 Gitea 用户和服务,确保 Gitea 在系统启动时自动运行。用户可以选择从官方或小绿叶技术博客下载安装包。
84 2
ip和ip网段攻击拦截系统-绿叶结界防火墙系统shell脚本
这是一个名为“小绿叶技术博客扫段攻击拦截系统”的Bash脚本,用于监控和拦截TCP攻击。通过抓取网络数据包监控可疑IP,并利用iptables和firewalld防火墙规则对这些IP进行拦截。同时,该系统能够查询数据库中的白名单,确保合法IP不受影响。此外,它还具备日志记录功能,以便于后续分析和审计。
70 6
深入理解Linux系统下的Shell脚本编程
【10月更文挑战第24天】本文将深入浅出地介绍Linux系统中Shell脚本的基础知识和实用技巧,帮助读者从零开始学习编写Shell脚本。通过本文的学习,你将能够掌握Shell脚本的基本语法、变量使用、流程控制以及函数定义等核心概念,并学会如何将这些知识应用于实际问题解决中。文章还将展示几个实用的Shell脚本例子,以加深对知识点的理解和应用。无论你是运维人员还是软件开发者,这篇文章都将为你提供强大的Linux自动化工具。
|
3月前
|
shell脚本编程学习
【10月更文挑战第1天】shell脚本编程
92 12
自动化运维:使用Shell脚本简化日常任务
【9月更文挑战第35天】在IT运维的日常工作中,重复性的任务往往消耗大量的时间。本文将介绍如何通过编写简单的Shell脚本来自动化这些日常任务,从而提升效率。我们将一起探索Shell脚本的基础语法,并通过实际案例展示如何应用这些知识来创建有用的自动化工具。无论你是新手还是有一定经验的运维人员,这篇文章都会为你提供新的视角和技巧,让你的工作更加轻松。
109 2
shell脚本变量 $name ${name}啥区别
shell脚本变量 $name ${name}啥区别
常用的 55 个 Linux Shell 脚本(包括基础案例、文件操作、实用工具、图形化、sed、gawk)
这篇文章提供了55个常用的Linux Shell脚本实例,涵盖基础案例、文件操作、实用工具、图形化界面及sed、gawk的使用。
871 2
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等