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

Windows Batch (.bat) 脚本语法详解:从入门到实战

文章目录一、 引言什么是 Batch 脚本二、 创建和运行 Bat 文件三、 基础语法与命令1. 注释2. 命令回显3. 变量4. 控制流条件判断 (IF)5. 循环 (FOR)6. 跳转 (GOTO)7. 退出 (EXIT)8. 其他常用命令四、 实战示例示例 1: 简单备份脚本示例 2: 交互式菜单脚本五、 注意事项与最佳实践六、 总结一、 引言什么是 Batch 脚本Batch 文件.bat或.cmd是一种文本文件包含一系列 Windows 命令按顺序执行。它类似于 Linux/Unix 系统中的 Shell 脚本.sh主要用于自动化重复性任务、批处理操作、系统管理、环境配置等。虽然 PowerShell 功能更强大、更现代但对于一些简单的自动化任务或在某些受限环境中.bat脚本仍然是一个快速有效的解决方案。二、 创建和运行 Bat 文件创建: 使用任何纯文本编辑器如 Notepad, VS Code, Sublime Text创建一个文件例如my_script.bat。编写: 在文件中写入命令。保存: 确保文件扩展名为.bat。运行:双击.bat文件图标在 Windows 资源管理器中。在命令提示符CMD中导航到脚本所在目录然后输入脚本名称例如my_script.bat并按回车。在 CMD 中直接输入完整路径例如C:\path\to\my_script.bat。三、 基础语法与命令1. 注释在.bat脚本中使用REM(Remark) 或::来添加注释。::后面的内容会被完全忽略而REM后面的内容也会被忽略但REM本身仍被视为命令的一部分尽管不执行任何操作。REM 这是一个注释 ECHO Hello World! :: 这也是一个注释 ECHO Goodbye!2. 命令回显默认情况下命令提示符会显示脚本中执行的每一行命令。使用ECHO OFF可以关闭这种回显使输出更干净。通常ECHO OFF会放在脚本的第一行。符号用于抑制该命令本身的回显。ECHO OFF ECHO This line will print without showing the command itself. ECHO Hello from script! PAUSE3. 变量环境变量: Windows 提供了许多预定义的环境变量如%PATH%,%USERNAME%,%USERPROFILE%,%OS%,%DATE%,%TIME%等。你也可以设置自己的环境变量。用户定义变量: 使用SET命令来设置变量。SET MYVARHello World ECHO %MYVAR%命令行参数: 当你运行脚本时传入的参数可以用%0到%9来引用。%0是脚本本身的路径%1是第一个参数%2是第二个参数以此类推。%*表示所有参数。ECHO OFF ECHO Script Name: %0 ECHO First Argument: %1 ECHO Second Argument: %2 ECHO All Arguments: %*4. 控制流条件判断 (IF)IF语句用于根据条件执行不同的命令块。比较字符串:SET INPUTapple IF %INPUT%apple ( ECHO You entered apple! ) ELSE ( ECHO You did not enter apple. )注意: 字符串比较时最好用双引号将变量和字符串括起来以处理包含空格的情况。比较数字:SET NUM10 IF %NUM% EQU 10 ( ECHO Number is equal to 10. ) ELSE ( ECHO Number is not equal to 10. )EQU: Equal ToNEQ: Not Equal ToLSS: Less ThanLEQ: Less Than or Equal ToGTR: Greater ThanGEQ: Greater Than or Equal To检查文件或目录是否存在:IF EXIST C:\temp ( ECHO Directory exists. ) ELSE ( ECHO Directory does not exist. ) IF NOT EXIST C:\somefile.txt ( ECHO File does not exist. )检查错误级别 (ERRORLEVEL): 许多命令执行后会设置一个错误级别码0 通常表示成功非 0 表示失败。IF ERRORLEVEL n会检查错误级别是否大于或等于n。REM 假设某个命令可能失败 dir nonexistent_directory IF ERRORLEVEL 1 ( ECHO The previous command failed. ) ELSE ( ECHO The previous command succeeded. )推荐替代: 现代写法更倾向于使用||(或) 和(与) 操作符来处理命令的成功或失败。dir nonexistent_directory || ECHO Command failed dir existing_directory ECHO Command succeeded5. 循环 (FOR)FOR循环用于重复执行命令。遍历列表:FOR %%i IN (apple banana cherry) DO ( ECHO Fruit: %%i )注意: 在脚本中使用FOR循环时循环变量如i前面需要两个百分号%%。在命令行直接执行时只需要一个%。遍历文件:FOR %%f IN (*.txt) DO ( ECHO Processing file: %%f REM Add commands to process each .txt file here )遍历目录:FOR /D %%d IN (*) DO ( ECHO Directory: %%d )数字范围循环 (FOR /L):FOR /L %%i IN (1, 1, 5) DO ( ECHO Count: %%i )这表示从 1 开始 (1)每次增加 1 (1)直到 5 (5)。遍历命令输出 (FOR /F): 这个选项非常强大可以处理另一个命令的输出。FOR /F tokens* %%a IN (dir /b *.txt) DO ( ECHO Found text file: %%a )dir /b *.txt是要执行的命令。tokens*表示将整行输出作为一个令牌赋值给变量%%a。6. 跳转 (GOTO)GOTO语句用于无条件跳转到脚本中标记的位置标签。标签以冒号:开头。ECHO OFF ECHO Starting... GOTO :middle ECHO This line will never execute :middle ECHO In the middle! :end ECHO Ending...7. 退出 (EXIT)EXIT: 终止脚本执行。EXIT /B: 从子程序或脚本中退出而不终止整个 CMD 会话如果是在 CMD 中直接调用脚本。EXIT /B errorlevel: 可以指定一个错误级别码退出。8. 其他常用命令ECHO [message]: 显示消息或控制回显。PAUSE: 暂停脚本执行等待用户按键。CLS: 清屏。CD /D [path]: 改变当前驱动器和目录。MD/MKDIR [dirname]: 创建目录。RD/RMDIR [dirname]: 删除目录。COPY [source] [destination]: 复制文件。MOVE [source] [destination]: 移动文件。DEL/ERASE [filename]: 删除文件。TYPE [filename]: 显示文件内容。START [program]: 启动一个程序或打开一个文件/URL。CALL [script.bat]: 调用另一个批处理脚本执行完后返回当前脚本继续执行。如果不用CALL则会执行另一个脚本后不再返回。四、 实战示例示例 1: 简单备份脚本ECHO OFF SETLOCAL ENABLEDELAYEDEXPANSION REM --- Backup Script Configuration --- SET SOURCE_DIRC:\MyData SET BACKUP_DIRD:\Backup SET TIMESTAMP%DATE:~0,4%_%DATE:~5,2%_%DATE:~8,2%_%TIME:~0,2%_%TIME:~3,2%_%TIME:~6,2% SET TIMESTAMP!TIMESTAMP: 0! REM Replace spaces in time with 0 SET BACKUP_NAMEBackup_!TIMESTAMP! REM Check if source directory exists IF NOT EXIST !SOURCE_DIR! ( ECHO Error: Source directory !SOURCE_DIR! does not exist. PAUSE EXIT /B 1 ) REM Create backup directory MD !BACKUP_DIR!\!BACKUP_NAME! REM Perform copy XCOPY !SOURCE_DIR! !BACKUP_DIR!\!BACKUP_NAME! /E /I /Y ECHO Backup completed: !BACKUP_NAME! PAUSESETLOCAL ENABLEDELAYEDEXPANSION: 启用延迟变量扩展这对于在循环中修改和使用变量很有用虽然这里没用到但这是一个好习惯。!VARIABLE!: 使用!而不是%来引用在ENABLEDELAYEDEXPANSION后被修改的变量。%DATE:~offset,length%: 字符串切片操作用于从日期字符串中提取年月日。XCOPY: 更强大的复制命令/E包含空子目录/I如果目标不存在则假设它是目录/Y不提示确认覆盖。示例 2: 交互式菜单脚本ECHO OFF :menu CLS ECHO. ECHO Main Menu ECHO ECHO 1. Say Hello ECHO 2. List Files in Current Directory ECHO 3. Exit ECHO. SET /P CHOICEEnter your choice (1-3): IF %CHOICE%1 GOTO :say_hello IF %CHOICE%2 GOTO :list_files IF %CHOICE%3 GOTO :exit_script ECHO Invalid choice. Please try again. PAUSE GOTO :menu :say_hello ECHO. ECHO Hello, World! PAUSE GOTO :menu :list_files ECHO. DIR PAUSE GOTO :menu :exit_script ECHO. ECHO Thank you for using this script. Goodbye! PAUSESET /P: 提示用户输入并存储到变量。使用GOTO和标签 (:label) 创建菜单循环。五、 注意事项与最佳实践路径和空格: 包含空格的路径需要用双引号括起来如C:\Program Files\MyApp.变量引用: 始终使用双引号将变量括起来进行比较或使用如%VAR%以避免因为空格或特殊字符导致的问题。错误处理: 考虑命令执行失败的可能性并进行适当的处理使用||,,IF ERRORLEVEL,EXIT /B。SETLOCAL和ENDLOCAL: 在脚本开头使用SETLOCAL可以创建一个局部环境脚本结束时会自动恢复之前的环境变量设置防止污染全局环境。调试: 在开发阶段可以暂时去掉ECHO OFF查看脚本实际执行的命令。六、 总结Windows Batch 脚本虽然语法相对简单但功能强大对于自动化日常任务非常有用。掌握其基础语法变量、条件、循环、跳转和常用命令可以大大提高工作效率。尽管 PowerShell 是更现代的选择但.bat脚本因其简单性和普遍性在许多场景下依然不可或缺。

相关文章:

Windows Batch (.bat) 脚本语法详解:从入门到实战

文章目录一、 引言:什么是 Batch 脚本?二、 创建和运行 Bat 文件三、 基础语法与命令1. 注释2. 命令回显3. 变量4. 控制流:条件判断 (IF)5. 循环 (FOR)6. 跳转 (GOTO)7. 退出 (EXIT)8. 其他常用命令四、 实战示例示例 1: 简单备份脚本示例 2:…...

终极CORS解决方案:gin-contrib/cors中间件完全指南

终极CORS解决方案:gin-contrib/cors中间件完全指南 【免费下载链接】cors Official CORS gins middleware 项目地址: https://gitcode.com/gh_mirrors/cors/cors 跨域资源共享(CORS)是现代Web开发中常见的挑战,而gin-contr…...

告别模拟器:3分钟在Windows上安装安卓应用的终极指南

告别模拟器:3分钟在Windows上安装安卓应用的终极指南 【免费下载链接】APK-Installer An Android Application Installer for Windows 项目地址: https://gitcode.com/GitHub_Trending/ap/APK-Installer 你是否曾想过在Windows电脑上直接运行安卓应用&#x…...

终极浏览器资源嗅探指南:猫抓Cat-Catch完整使用教程

终极浏览器资源嗅探指南:猫抓Cat-Catch完整使用教程 【免费下载链接】cat-catch 猫抓 浏览器资源嗅探扩展 / cat-catch Browser Resource Sniffing Extension 项目地址: https://gitcode.com/GitHub_Trending/ca/cat-catch 还在为无法保存在线视频而烦恼吗&a…...

OpenClaw插件实现聊天工具与Codex开发助手无缝集成

1. 项目概述:在聊天中无缝接入你的本地开发工作流如果你和我一样,日常开发工作流重度依赖像 Codex 这样的智能编码助手,同时又习惯了在 Telegram 或 Discord 的群聊、频道里和团队沟通,那么你很可能面临一个割裂的体验&#xff1a…...

Leptonica源码架构分析:理解2700+函数的设计哲学

Leptonica源码架构分析:理解2700函数的设计哲学 【免费下载链接】leptonica Leptonica is an open source library containing software that is broadly useful for image processing and image analysis applications. The official github repository for Lepton…...

保姆级避坑指南:从零复现Medical SAM Adapter,搞定皮肤、眼底、腹部CT三大医学数据集

医学影像分割实战:Medical SAM Adapter三大数据集复现全流程解析 当Meta的Segment Anything Model(SAM)遇上医学影像分析,会碰撞出怎样的火花?Medical SAM Adapter作为首个将通用分割大模型适配到医学领域的开源解决方…...

Hawk在微服务架构中的应用:分布式系统的认证解决方案

Hawk在微服务架构中的应用:分布式系统的认证解决方案 【免费下载链接】hawk INACTIVE - HTTP Holder-Of-Key Authentication Scheme 项目地址: https://gitcode.com/gh_mirrors/hawk/hawk 在当今快速发展的分布式系统环境中,微服务架构凭借其灵活…...

从科研到产线:锁相放大器(LIA)在光电探测和AFM中的应用实战与选型指南

从科研到产线:锁相放大器在光电探测与AFM中的实战应用与选型策略 在精密测量领域,信噪比往往决定着实验的成败。当信号强度跌至纳伏甚至皮伏量级时,传统放大器的局限性便暴露无遗——它们会平等地放大信号和噪声。这种现象在拉曼光谱实验中尤…...

WCC与QEMU用户模式结合:实现原生二进制翻译和分析的终极指南

WCC与QEMU用户模式结合:实现原生二进制翻译和分析的终极指南 【免费下载链接】wcc The Witchcraft Compiler Collection 项目地址: https://gitcode.com/gh_mirrors/wc/wcc The Witchcraft Compiler Collection(WCC)是一个功能强大的编…...

如何高效控制macOS外接显示器:MonitorControl完整使用指南

如何高效控制macOS外接显示器:MonitorControl完整使用指南 【免费下载链接】MonitorControl 🖥 Control your displays brightness & volume on your Mac as if it was a native Apple Display. Use Apple Keyboard keys or custom shortcuts. Shows…...

Hyprland下Waydroid运行Roblox的鼠标锁定方案

1. 项目概述:解决Waydroid中玩Roblox的鼠标逃逸问题 如果你和我一样,在Linux的Hyprland窗口管理器下,通过Waydroid运行Android应用,并且是个Roblox玩家,那你肯定遇到过这个让人抓狂的问题:鼠标光标动不动就…...

揭秘MPC-BE媒体播放器的5大核心技术架构与实战部署

揭秘MPC-BE媒体播放器的5大核心技术架构与实战部署 【免费下载链接】MPC-BE MPC-BE – универсальный проигрыватель аудио и видеофайлов для операционной системы Windows. 项目地址: https://gitcode.…...

004-利用Docker安装Mysql

利用Docker安装Mysql一、在镜像仓库找到 Mysql1.镜像仓库地址2.复制命令3.下载Mysql镜像4.查看镜像二、创建实例并启动三、用本地工具连接数据库四、设置 Mysql 配置一、在镜像仓库找到 Mysql Docker 容器默认是临时存储,若容器删除,MySQL 数据会丢失。…...

TheCherno——Engine(五)

事件系统计划:Application中可以了解Window的所有信息,在Application的构造函数中,就可以创建一个Window类;Window中监测事件的发生,若事件发生,有相应的回调函数响应;在回调函数中,…...

Ryujinx深度解析:从架构设计到性能调优的任天堂Switch模拟器实战指南

Ryujinx深度解析:从架构设计到性能调优的任天堂Switch模拟器实战指南 【免费下载链接】Ryujinx 用 C# 编写的实验性 Nintendo Switch 模拟器 项目地址: https://gitcode.com/GitHub_Trending/ry/Ryujinx Ryujinx作为用C#编写的开源Nintendo Switch模拟器&…...

2026数据科学技术趋势全解析:新兴领域与高效学习路径指南

2026数据科学技术趋势全解析:新兴领域与高效学习路径指南 【免费下载链接】data-science 📊 Path to a free self-taught education in Data Science! 项目地址: https://gitcode.com/gh_mirrors/da/data-science GitHub 加速计划 / da / data-sc…...

为内部知识库问答工具集成 Taotoken 提供的多模型检索增强

为内部知识库问答工具集成 Taotoken 提供的多模型检索增强 在企业知识管理实践中,内部知识库问答工具是提升信息流转效率的关键。然而,单一模型在应对复杂、专业或需要多角度推理的查询时,其回答质量可能受限。通过集成 Taotoken 平台&#…...

明日方舟游戏资源库:你的终极素材宝库与创作指南

明日方舟游戏资源库:你的终极素材宝库与创作指南 【免费下载链接】ArknightsGameResource 明日方舟客户端素材 项目地址: https://gitcode.com/gh_mirrors/ar/ArknightsGameResource 还在为寻找高质量的明日方舟游戏素材而苦恼吗?想要获取高清角色…...

AI执行契约:结构化协作框架,提升AI产品构建效率与确定性

1. 项目概述:从灵感到成品的AI驱动产品构建框架如果你和我一样,经常使用 Cursor、Claude 或 ChatGPT 来辅助构建产品原型或功能,那你一定经历过这样的场景:你有一个绝佳的想法,兴冲冲地打开 AI 对话窗口,开…...

将 Taotoken 配置为 Claude Code 编程助手的自定义模型提供商

将 Taotoken 配置为 Claude Code 编程助手的自定义模型提供商 Claude Code 是一款专注于代码生成与编程辅助的 AI 工具,它支持通过自定义配置连接到不同的模型服务。对于希望统一管理多个模型调用、并希望获得稳定计费与用量观测的开发者而言,将 Taotok…...

基于提示词工程的AI智慧日报系统:零代码实现跨文化历史故事生成

1. 项目概述:一个永不重复的AI智慧日报系统每天早晨,当大多数人还在与闹钟挣扎时,我已经习惯性地打开手机,期待一份独特的“精神早餐”。它不是来自某个新闻客户端,也不是来自社交媒体的信息流,而是一段由A…...

开源ChatGPT WebUI:自托管部署、核心功能与安全实践全解析

1. 项目概述:一个开源ChatGPT WebUI的诞生与价值最近在GitHub上看到一个名为“HemulGM/ChatGPT”的项目,点进去一看,发现这是一个基于Web的ChatGPT用户界面。作为一个长期关注AI应用落地的开发者,我立刻来了兴趣。这不仅仅是一个简…...

ComfyUI-OpenClaw:为AI工作流注入安全灵魂的自动化控制层

1. 项目概述:ComfyUI-OpenClaw,一个为AI工作流注入“安全灵魂”的自动化控制层如果你和我一样,长期在本地折腾Stable Diffusion和ComfyUI,肯定遇到过这样的困境:想用AI辅助生成提示词,得手动切到另一个网页…...

为AI工具协议MCP构建零信任安全代理:从OAuth到RBAC的实战指南

1. 项目概述:为AI工具协议筑起安全围墙最近在折腾AI Agent的开发,发现一个挺有意思但容易被忽视的安全问题。我们都在用Claude、Cursor、Copilot这些工具,它们背后连接各种数据源和服务,靠的是一个叫MCP(Model Context…...

OpenRelay:本地AI代理聚合工具,统一调度Claude、Cursor等多平台订阅与API

1. 项目概述:打破AI订阅的孤岛如果你和我一样,每天要在Claude Desktop、Cursor、Aider、Goose这些AI工具之间来回切换,那你一定深有体会:每个工具的订阅配额都是独立的“信息孤岛”。Claude Pro的额度只能在Claude官方客户端里用&…...

Cursor AI 效率革命:MCP.json 构建器与开源工具站实战指南

1. 项目概述:一个为 Cursor AI 用户打造的“百宝箱” 如果你和我一样,日常重度依赖 Cursor 这款 AI 驱动的代码编辑器,那你肯定遇到过这样的场景:想快速接入一个外部数据源,比如查查 AWS 文档,或者调用下 …...

如何快速开发车牌识别新特征?EasyPR模板工具让你5分钟上手

如何快速开发车牌识别新特征?EasyPR模板工具让你5分钟上手 【免费下载链接】EasyPR (CGCSTCD2017) An easy, flexible, and accurate plate recognition project for Chinese licenses in unconstrained situations. CGCSTCD China Graduate Contest on Smart-city…...

AI Agent技能开发实战:逆向工程赋能餐厅搜索自动化

1. 项目概述:一个为AI助手赋能的餐厅搜索技能 如果你在以色列生活或旅行,想在Ontopo这个主流餐厅预订平台上找个好位子,大概率经历过这样的折磨:打开网站或App,选好餐厅,点开日历,一天一天地往…...

如何用MobileSAM与Inpaint-Anything实现高效图像修复:完整实战指南

如何用MobileSAM与Inpaint-Anything实现高效图像修复:完整实战指南 【免费下载链接】MobileSAM This is the official code for MobileSAM project that makes SAM lightweight for mobile applications and beyond! 项目地址: https://gitcode.com/gh_mirrors/mo…...