当前位置: 首页 > news >正文

Shell脚本-随机数实战案例

在Shell脚本编程中,生成随机数是一项非常实用的技能。无论是用于模拟、测试、游戏开发还是安全相关的应用(如生成密码),能够灵活地生成随机数都是非常有用的。本文将通过几个实际的应用案例来展示如何在Shell脚本中使用随机数解决问题。

案例一:猜数字游戏

创建一个简单的命令行猜数字游戏,玩家需要猜测由脚本随机生成的一个数字。

脚本示例:

#!/bin/bashnumber=$((RANDOM % 100 + 1)) # 生成1到100之间的随机数
guess=-1echo "Guess the number between 1 and 100."while [ $guess -ne $number ]; doread -p "Enter your guess: " guessif [ $guess -lt $number ]; thenecho "Too low!"elif [ $guess -gt $number ]; thenecho "Too high!"elseecho "Congratulations! You guessed it right."fi
done

说明:

  • 使用$RANDOM生成1到100之间的随机整数。
  • while循环持续进行直到用户猜对为止。
  • 根据用户的输入给出相应的提示信息。

案例二:文件名随机化

假设你需要批量重命名一组文件,并希望新文件名是随机生成的字符串。

脚本示例:

#!/bin/bashdirectory="/path/to/your/files"
cd "$directory" || exitfor file in *; doextension="${file##*.}"new_name="$(date +%s%N)-$RANDOM.$extension" # 使用时间戳和随机数作为新文件名mv "$file" "$new_name"echo "Renamed '$file' to '$new_name'"
done

说明:

  • for file in *遍历指定目录下的所有文件。
  • 使用当前时间戳(纳秒精度)和随机数组合成新的文件名。
  • mv "$file" "$new_name"执行重命名操作。

案例三:数据库查询结果随机排序

有时你可能希望从数据库查询的结果中随机选择几条记录,或者随机打乱查询结果的顺序。

脚本示例:

#!/bin/bashdb_user="your_db_user"
db_password="your_db_password"
db_name="your_db_name"query="SELECT * FROM your_table ORDER BY RAND() LIMIT 5;" # MySQL示例
mysql -u "$db_user" -p"$db_password" "$db_name" -e "$query"

说明:

  • ORDER BY RAND()用于MySQL数据库,可以随机排列查询结果。
  • -e选项允许直接在命令行中执行SQL语句。
  • 注意:这种方法对于大数据集可能会比较慢,因为它需要为每一行分配随机值并排序。

案例四:生成随机密码

编写一个脚本来生成指定长度的随机密码,适用于需要定期更换密码或为新用户生成初始密码的情况。

脚本示例:

#!/bin/bashlength=12
password=$(< /dev/urandom tr -dc 'A-Za-z0-9!@#$%^&*()' | head -c $length)
echo "Generated password: $password"

说明:

  • < /dev/urandom tr -dc 'A-Za-z0-9!@#$%^&*()'/dev/urandom读取数据,并过滤出所需的字符集。
  • head -c $length截取指定长度的字符串作为密码。

案例五:随机抽奖

假设你需要从一组参与者中随机抽取若干幸运儿,例如举办活动时进行抽奖。

脚本示例:

#!/bin/bashparticipants=("Alice" "Bob" "Charlie" "David" "Eve")
number_of_winners=3for ((i=0; i<number_of_winners; i++)); doindex=$((RANDOM % ${#participants[@]}))winner=${participants[$index]}echo "Winner $((i+1)): $winner"unset participants[$index] # 移除已抽中的参与者以避免重复participants=("${participants[@]}") # 重新索引数组
done

说明:

  • ${#participants[@]}获取数组的长度。
  • unset participants[$index]移除已经抽中的参与者。
  • 重新索引数组确保后续抽取不会受到之前操作的影响。

结语

感谢您的阅读!如果你有任何疑问或想要分享的经验,请在评论区留言交流!

http://www.xdnf.cn/news/189667.html

相关文章:

  • 数据结构 -- 图的应用(二)
  • 机器学习中的数据转换:关键步骤与最佳实践
  • 多模态革命!拆解夸克AI相机技术架构:如何用视觉搜索重构信息交互?(附开源方案对比)
  • 讯飞星辰焕新发布!Agent规模化应用的通关密码
  • 【“星瑞” O6 评测】 — CPU llama.cpp不同优化速度对比
  • 【Shell 脚本入门】轻松上手的实战指南
  • 深度学习: AI 体育领域
  • 成员方法的详细说明(结合Oracle官方文档)
  • 12分区 3号机 送风分区送风 会远程启,不会远停
  • 搭建dns的正向解析
  • QGIS+mcp的安装和使用
  • DeepSeek智能时空数据分析(六):大模型NL2SQL绘制城市之间连线
  • 云原生开发革命:iVX 如何实现 “资源即插即用” 的弹性架构?
  • 《Masked Autoencoders Are Scalable Vision Learners》---CV版的BERT
  • 微信小程序开发中关于首屏加载、本地数据持久化的思考
  • 旋转位置编码RoPE
  • TypeScript中的函数类型定义与类型约束
  • 有哪些和PPT自动生成有关的MCP项目?
  • 详解RabbitMQ工作模式之简单模式
  • Vue 对话框出现时,为什么滚动鼠标还是能滚动底层元素
  • Docker 常用命令(涵盖多个方面)
  • 数据结构第七章(一)-顺序查找和折半查找
  • CMCC RAX3000M使用Tftpd刷写OpenWrt固件的救砖方法
  • Python实现SSE流式推送
  • AutoGen 框架深度解析:构建多智能体协作的事件驱动架构
  • SQL 易混易错知识点笔记1(drop,role,%,localhost)
  • Flinkcdc 实现 MySQL 写入 Doris
  • 导入使用 Blender 创建的 glTF/glb 格式的 3D 模型
  • 从千兆到40G:飞速(FS)助力制造企业构建高可靠智能生产网络
  • Ocelot的应用案例