1.for循环使用场景

1. 需要反复、重复执行的任务
2. 如创建100个用户,打印一百遍 chaoge666、插入数据库一万条数据等。

2.for语法

for 变量名 in 取值列表
do
每次循环要执行的命令
done # for默认以空格分割独立的元素

3.for循环几个场景

3.1 循环多个字符串参数

场景1,多个单个参数

#!/bin/bash
for cai in "红烧肉" "酱牛肉" "烤羊肉串" "烤土豆片"
do
echo "菜品:" $cai
done

场景2,不一样的写法,如下结果是什么?

#!/bin/bash
for cai in "红烧肉 五花肉 爆炒腰花" "酱牛肉 酱牛毽子" "烤羊肉串 烤羊宝" "烤土豆片 烤菜花"
do
echo "菜品:" $cai
done

3.2 从变量中循环取值

简单语法

#!/bin/bash

all_cal="红烧肉 五花肉 爆炒腰花 酱牛肉 酱牛毽子 烤羊肉串 烤羊宝 烤土豆片 烤菜花"

for cai in $all_cal
do
echo $cai
done

需求:提取现有机器上PATH变量的每一个路径。

#!/bin/bash
local_path=$(echo $PATH | sed 's/\:/ /g')
for p in $local_path
do
echo $p
done

3.3 读取花括号序列

#!/bin/bash
for num in {0..15}
do
echo "循环的数字是:$num"
done

写法2,c语言风格,了解即可

#!/bin/bash

for (( num=0;num<15;num++ ))
do
echo "循环的数字是:${num}"
done

3.4 从文件读取数据

注意,for循环是以遇见空格来进行换行,确认每一个元素,因此注意这个细节。

cat > shaokao.log <<'EOF'
烤羊头 烤羊肉串 烤羊宝
烤韭菜
烤土豆
EOF # 循环读取
for cai in $(cat shaokao.log)
do
echo "老板,来俩: $cai"
done

3.5 循环创建用户

#!/bin/bash
for num in {1..10}
do
# 创建用户
echo "$(useradd yu${num})"
# 创建密码
echo "$(echo pwd${num}|passwd --stdin yu${num})"
done

3.6 循环删除用户

#!/bin/bash
for user in yu{1..10}
do
userdel ${user}
done

3.7 使用case开发用户创建脚本

提供菜单选项
1. useradd
2. userdel
以及输入用户名前缀,即可快速创建10个用户

代码

#!/bin/bash
echo -e "====用户快捷创建系统=====
1. 用户创建
2. 用户删除" read -p "请选择你要执行的操作:" choice case $choice in
1)
read -p "请输入用户名前缀:" user
read -p "请输入密码前缀:" pwd
# 循环创建10个用户
for num in {1..10}
do
useradd ${user}${num}
echo ${pwd}${num}|passwd --stdin ${user}${num}
done
;; 2)
read -p "请输入要删除的用户名前缀:" del_user
for num in {1..10}
do
userdel -r ${del_user}${num}
done
;;
*)
echo "只支持1~2选项!!"
esac

3.8 读取密码本,创建用户

密码本

cat >user_info.log<<'EOF'
user1:pass1
user2:pass2
user3:pass3
user4:pass4
user5:pass5
user6:pass6
user7:pass7
user8:pass8
user9:pass9
user10:pass10
EOF

开发脚本读取密码本,创建用户且设置密码

for i in $(cat user_info.log)
do
# 提取用户名
user=$(echo $i|awk -F':' '{print $1}')
# 创建用户
useradd ${user}
# 提取密码
pwd=$(echo $i|awk -F':' '{print $2}')
# 创建密码
echo ${pwd}|passwd --stdin ${user}
done

3.9 主机存活检测

这种写法是单进程检测

#!/bin/bash
for i in {1..254}
do
ping -w 1 192.168.3.${i} > /dev/null 2>&1
# 存活判断
if [ $? == 0 ];then
echo "172.16.1.${i} 运行中" > online_ip.log
fi
done #!/bin/bash
for i in {1..254}
do
ping -w 1 192.168.3.${i}
# 存活判断
if [ $? == 0 ];then
echo "172.16.1.${i} 运行中"
fi
done

优化写法,全部放入后台执行,并发执行。

可以通过jobs查后台进程列表。

#!/bin/bash
> ip.txt for ip in {1..254}
do
ping -w 1 192.168.3.${ip} >> ip.txt &
done echo "存活主机如下:"
# 寻找有数据包返回的行就行了
awk -F"[: ]" '/icmp/{print $4}' ip.txt

3.10 提取于超老师博客园博文链接

# 思路

# 步骤1.下载超哥博客园首页html,里面有相关文章的url,提取即可
curl -s https://www.cnblogs.com/pyyu -o www.yuchaoit.cn.html # 思路1,提取出关于具体文章的url,请用多种命令提取。
awk -F'\"' '/postTitle2/{print $4}' www.yuchaoit.cn.html > all_url.log
grep 'postTitle2' www.yuchaoit.cn.html |grep -o 'ht.*l'
grep 'postTitle2' www.yuchaoit.cn.html |sed -r 's/(^.*)="(.*)">/\2/g'
grep 'postTitle2' www.yuchaoit.cn.html |sed -r 's/.*="(.*)">/\1/g' # 思路2,提取出文章的标题
sed -rn '/postTitle2/,/<\/span>/p' www.yuchaoit.cn.html |grep -Ev '[<>]' | sed 's/ //g' > all_title.log # 思路3,拼接url和标题(paste命令)
[root@www.yuchaoit.cn ~]#paste -d " " all_title.log all_url.log > chaoge_blog.log
[root@www.yuchaoit.cn ~]#
[root@www.yuchaoit.cn ~]#cat chaoge_blog.log |column -t # 思路4,shell拼接url和标题(遍历数组写法)
all_url=($(cat all_url.log))
all_title=($(cat all_title.log))
url_num=$(cat all_url.log|wc -l)
for (( i=0;i<$url_num;i++ ))
do
echo -e "【于超老师博客】${all_url[i]} \t ${all_title[i]}"
done # 思路5
title_num=$(cat all_title.log|wc -l)
# 循环用sed打印每一行,拼接即可
for line_num in $(seq 1 ${title_num})
do
each_title=$(sed -n "${line_num}"p all_title.log)
each_url=$(sed -n "${line_num}"p all_url.log)
echo -e "${each_title} \t ${each_url}" >> chaoge_blog.log
done # 查看结果
cat chaoge_blog.log |column -t

3.11 mysql数据库分库分表备份

mysql备份方案1,全库、全表备份

mysqldump -uroot -pwww.yuchaoit.cn -A -B --single-transaction > /opt/all-db.sql
一般备份时都会进行压缩处理,以节省磁盘空间,如下 mysqldump -uroot -pwww.yuchaoit.cn -A -B --single-transaction | gzip >/opt/all-db.sql

还有一种备份方案,可以按不同的库,以及对于库中的表,进行备份,更为独立。

现有的数据库
[root@db-51 ~]#mysql -uroot -pwww.yuchaoit.cn
Welcome to the MariaDB monitor. Commands end with ; or \g.
Your MariaDB connection id is 9
Server version: 5.5.68-MariaDB MariaDB Server Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. MariaDB [(none)]> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| test |
| wordpress |
+--------------------+
5 rows in set (0.00 sec)

库和表的结构是

如wordpress数据库的数据表如下

MariaDB [(none)]> use wordpress;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A Database changed
MariaDB [wordpress]> show tables;
+-----------------------+
| Tables_in_wordpress |
+-----------------------+
| wp_commentmeta |
| wp_comments |
| wp_links |
| wp_options |
| wp_postmeta |
| wp_posts |
| wp_term_relationships |
| wp_term_taxonomy |
| wp_termmeta |
| wp_terms |
| wp_usermeta |
| wp_users |
+-----------------------+
12 rows in set (0.00 sec)

需求

1. 将wordpress数据库单独备份到 /backup_mysql/wordpress/
2. 以及对应的数据表
/backup_mysql/wordpress/wp_posts.sql

思路

1. 查看库下的表
[root@db-51 ~]#mysql -uroot -pwww.yuchaoit.cn -e "show tables from wordpress;" 2. 单独导出库中的表数据
mysqldump -uroot -pwww.yuchaoit.cn wordpress wp_posts > /backup/wordpress/wp_posts.sql

脚本开发

#!/bin/bash
now=$(date +%F-%T)
table_list=$(mysql -uroot -pwww.yuchaoit.cn -e "show tables from wordpress;" |grep -v 'Tables') if [ ! -d /backup/wordpress/ ];then
mkdir -p /backup/wordpress/
fi for table in ${table_list}
do
mysqldump -uroot -pwww.yuchaoit.cn wordpress ${table} > /backup/wordpress/${table}.sql.${now}
done

流程控制之for循环结构的更多相关文章

  1. (16)JavaScript的流程控制(js的循环)

    流程控制有3种结构 1.顺序结构:代码执行的本质就是顺序结构 2.分支结构:if家族 语法规则: if (条件1) { //代码块1}else if (条件2){ //代码块1}//如果所有条件都不满 ...

  2. 作业详解及流程控制之for循环

    作业详解及流程控制之for循环 目录 作业详解及流程控制之for循环 一.作业详解 1.根据用户输入内容打印其权限 2.编写用户登录程序 4.猜年龄的游戏 二.流程控制之for循环 三.while循环 ...

  3. SSIS从理论到实战,再到应用(4)----流程控制之For循环

    原文:SSIS从理论到实战,再到应用(4)----流程控制之For循环 上期回顾: SSIS从理论到实战,再到应用(3)----SSIS包的变量,约束,常用容器 在SSIS体系中,控制流可能经常会遇到 ...

  4. SSIS从理论到实战,再到应用(5)----流程控制之Foreach循环

    原文:SSIS从理论到实战,再到应用(5)----流程控制之Foreach循环 上期回顾: SSIS从理论到实战,再到应用(4)----流程控制之For循环 上一期讲了For循环,Foreach循环相 ...

  5. [转帖]流程控制:for 循环

    流程控制:for 循环 http://wiki.jikexueyuan.com/project/linux-command/chap34.html need more study need more ...

  6. day04流程控制之while循环

    流程控制之while循环 1.什么是while循环 循环指的是一个重复做某件事的过程 2.为何有循环 为了让计算机能像人一样重复 做某件事 3.如何用循环 ''' # while循环的语法:while ...

  7. php总结3——基本函数、流程控制中的循环

    3.1 php基本函数(数学.日期.字符串) 数学函数:max         mixed max(number $arg1,number $arg2,……)  求一组数据中的最大值        m ...

  8. php总结2——php中的变量、数据类型及转换、运算符、流程控制中的分支结构

    2.1  php中的变量: 定义变量:$变量名称=值: 变量名称:$开头    $之后的第一位必须是字母    $第二位之后可以是字母.数字或者是下划线.习惯上变量名称有实际含义,第二个单词后首字母大 ...

  9. 流程控制之while循环for循环

    流程控制之while循环1.什么是循环 循环就是重复做某件事2.为什么要有循环 为了让计算机能够具备人重复做某件事的能力3.如何用循环 while语法: while 条件: code1 code2 c ...

  10. 流程控制之 for 循环

    目录 流程控制之for循环 for 循环条件语句 for 循环的嵌套 流程控制之for循环 for 循环条件语句 for i in range(3): print(i) # 0 # 1 # 2 for ...

随机推荐

  1. 第 9章 数据分析案例:Python 岗位行情

    第 9章 数据分析案例:Python 岗位行情 9.1 数据爬取 (1)打开某招聘网站首页 https://www.lagou.com,选择"全国站",在搜索栏输入 Python, ...

  2. 阿里云交互式分析与Presto对比分析及使用注意事项

    阿里云交互式分析与Presto对比分析及使用注意事项本文由阿里巴巴耿江涛带来以"阿里云交互式分析与Presto对比分析及使用注意事项"为题的演讲.文章首先介绍了Presto以及它的 ...

  3. 阿里云图数据库GDB V3引擎发布,加速开启“图智”未来

    ​简介:无论是学术界还是产业界,都对图数据库有比较高的预期.Gartner发布的<2021年十大数据和分析技术趋势>中提到:"到2025年图技术在数据和分析创新中的占比将从202 ...

  4. 自己动手从0开始实现一个分布式RPC框架

    简介: 如果一个程序员能清楚的了解RPC框架所具备的要素,掌握RPC框架中涉及的服务注册发现.负载均衡.序列化协议.RPC通信协议.Socket通信.异步调用.熔断降级等技术,可以全方位的提升基本素质 ...

  5. [GPT] 用dogecoin接受付款,如何实现收款回调,不借助中心化的第三方

      要在不借助中心化的第三方的情况下实现Dogecoin的收款回调,您可以按照以下步骤进行操作: 1. 设置一个用于接收收款回调的URL:您需要在您的网站或应用程序中设置一个用于接收收款回调的URL. ...

  6. [Trading] 人物: 陈向忠日内交易技术核心 - 趋势形态与成交量

    分时图判断趋势(开仓方向) 只要是低点不断抬高的,就是上涨趋势,高点是否提高是其次的. 只要是高点不断降低的那就是下降趋势,假如低点也在不断降低,那么这样的下降趋势就更加完美一些. 很多人就是看对了趋 ...

  7. VisualStudio 禁用移动文件到文件夹自动修改命名空间功能

    在 VisualStudio 2022 里的某个版本开始,将会在移动文件到其他文件夹时,自动修改命名空间,使用匹配文件夹路径的命名空间.如果这个功能能顺手将其他引用此类型的全部符号同时变更,那自然是很 ...

  8. 适合IT团队的在线文档私人分享工具——showdoc部署

    转载文章: https://www.lixian.fun/3617.html

  9. ShareConnect即将寿终正寝 Splashtop远程桌面会是最好的替代品

    大家好,我是没有感情的翻译机器人,又见面了.同类产品ShareConnect即将退市,官方大大搞了个新闻稿.君叫臣翻,臣不得不翻.------没有感情的分割线------ShareConnect的使用 ...

  10. 腾讯云服务器sdk

    参考:https://cloud.tencent.com/document/product/494/7244 pip install -i https://mirrors.tencent.com/py ...