从菜鸟到高手!Shell脚本入门必学的8大实战案例(附代码)

2026年01月20日/ 浏览 9

从菜鸟到高手!Shell脚本入门必学的8大实战案例(附代码)——手把手教你用代码解决实际问题,3天变身脚本达人!

为什么Shell脚本是职场人的“效率神器”?

每天重复操作文件、整理数据、监控系统状态……手动操作不仅耗时,还容易出错!

Shell脚本 能自动执行这些枯燥任务,彻底解放双手!

本文目标

掌握Shell脚本基础语法学会用 8个实战案例 解决高频工作问题直接复制代码,立刻应用到实际场景!

实战案例1:批量解压文件(一键处理压缩包)

需求

:文件夹中有大量 .zip 和 .tar.gz 文件,需要全部解压到对应目录。

解决方案:用 find + bash循环 自动识别格式并解压。bash#!/bin/bash # unzip_all.sh for file in *.zip *.tar.gz; do if [[ $file == *.zip ]]; then unzip "$file" -d "${file%.zip}" elif [[ $file == *.tar.gz ]]; then tar -xzvf "$file" -C "${file%.tar.gz}" fi done

效果5秒解压所有文件,文件夹自动分类!

实战案例2:定时发送邮件提醒(再也不怕错过截止日期)

需求

:每天上午10点提醒自己提交周报。

解决方案:结合 crontab + mail 命令发送定时邮件。bash#!/bin/bash # email_reminder.sh SUBJECT="周报提交提醒" BODY="请于今日18:00前提交周报至team@company.com" echo "$BODY" | mail -s "$SUBJECT" your@email.com

设置定时任务

bashcrontab -e # 添加以下行(每天10:00执行): 0 10 * * * /path/to/email_reminder.sh

实战案例3:生成随机密码(从此告别简单密码)

需求

:生成一个包含大小写字母、数字的12位强密码。

解决方案:用 /dev/urandom + tr 过滤字符。bash#!/bin/bash # generate_password.sh PASSWORD=$(tr -dc A-Za-z0-9 < /dev/urandom | head -c 12) echo "你的随机密码是:$PASSWORD"

效果:每次运行生成唯一高强度密码,安全又方便!

实战案例4:CSV文件数据清洗(快速处理Excel数据)

需求

:去除CSV文件中的空行和重复数据。

解决方案:用 awk 和 sort 实现高效清洗。bash#!/bin/bash # clean_csv.sh INPUT="data.csv" OUTPUT="clean_data.csv" awk -F, !seen[$0]++ "$INPUT" | grep -v ^$ > "$OUTPUT"

效果3秒清理10万行数据,保留唯一有效记录!

实战案例5:监控网站可用性(自动检测并报警)

需求

:检测网站是否宕机,若失败则发邮件通知。

解决方案:用 curl 检查HTTP状态码,结合 mail 报警。bash#!/bin/bash # website_monitor.sh WEBSITE="https://example.com" EMAIL="admin@example.com" if ! curl --output /dev/null --silent --head --fail "$WEBSITE"; then echo "网站 $WEBSITE 不可用!" | mail -s "网站故障报警" "$EMAIL" fi

实战案例6:批量终止指定进程(一键清理后台任务)

需求

:关闭所有占用CPU超过80%的进程。

解决方案:用 ps + awk 筛选并强制终止。bash#!/bin/bash # kill_high_cpu.sh THRESHOLD=80 ps -eo pid,%cpu,comm --no-headers | awk -v limit="$THRESHOLD" $2 > limit {print $1} | xargs kill -9

警告:谨慎使用 kill -9,建议先手动检查进程!

实战案例7:同步文件到远程服务器(免密传输)

需求

:每天自动将本地文件备份到云服务器。

解决方案:用 rsync + SSH密钥免密登录。bash#!/bin/bash # sync_to_server.sh REMOTE_USER="user" REMOTE_IP="192.168.1.100" LOCAL_DIR="/home/user/data" REMOTE_DIR="/backup" rsync -avz -e ssh "$LOCAL_DIR/" "$REMOTE_USER@$REMOTE_IP:$REMOTE_DIR"

设置免密登录

bashssh-keygen -t rsa # 生成密钥 ssh-copy-id user@192.168.1.100 # 复制公钥到服务器

实战案例8:统计代码行数(程序员必备技能)

需求

:统计项目中所有 .py 文件的总行数。

解决方案:用 find + wc 递归计算。bash#!/bin/bash # count_lines.sh DIR="/path/to/project" find "$DIR" -name "*.py" -exec wc -l {} \; | awk {sum += $1} END {print "总行数:", sum}

效果:快速了解项目规模,面试/汇报必备!

Shell脚本学习路线图

基础语法:变量、条件判断、循环(if-else、for、while)。常用工具:grep(搜索)、sed(替换)、awk(数据处理)。实战进阶:结合 crontab 实现定时任务,用 ssh 远程操作。

今日行动清单

✅ 复制 generate_password.sh,生成你的专属密码!

✅ 用 clean_csv.sh 清理一份Excel数据,体验秒级操作!

✅ 在评论区分享你最想学的脚本场景(如自动签到、游戏外挂检测等)!

记住:Shell脚本是“自动化思维”的起点!无论是运维、开发还是数据分析,掌握它能让你效率翻倍!

✨ 代码即生产力,让重复劳动成为历史!✨

picture loss