在 Windows 终端中运行脚本:从入门到进阶的完整指南
在现代软件开发与系统管理实践中,终端(Terminal)已不再是 Linux/macOS 的专属工具。随着 Windows Terminal 的正式发布(2019年公开预览,2020年稳定版上线)以及 Windows Subsystem for Linux(WSL)的深度集成,Windows 用户拥有了强大、美观且高度可定制的命令行环境。然而,许多初学者仍面临一个基础却关键的问题:如何在 Windows 终端中正确运行各类脚本? 本文将系统性地梳理在 Windows 终端中运行脚本的全流程——涵盖批处理(.bat/.cmd)、PowerShell(.ps1)、Python(.py)、Node.js(.js)、Bash(.sh,通过 WSL)等主流脚本类型,并深入解析权限控制、执行策略、路径处理、编码兼容性及调试技巧,助您安全、高效、跨环境地驾驭脚本自动化。
理解 Windows 终端的本质:它不是“壳”,而是“窗口管理器”

需首先明确:Windows Terminal 本身不执行命令,它是一个现代化的终端模拟器(Terminal Emulator),用于承载和渲染各种命令行外壳(Shell)。真正负责解析与运行脚本的是底层 Shell,例如:
cmd.exe(传统命令提示符) powershell.exe 或 pwsh.exe(PowerShell Core / 7+) wsl.exe 启动的 Linux 发行版(如 Ubuntu)中的 bash/zsh git-bash(MinTTY 环境) 第三方 Shell(如 Cmder、ConEmu 配置的 Shell)因此,“在 Windows 终端中运行脚本”的本质,是在选定的 Shell 环境中,按其语法与规则调用并执行脚本文件。
运行不同脚本类型的实操方法
批处理脚本(.bat / .cmd)
这是最兼容的传统方式。在 cmd 或 PowerShell 中均可直接运行(PowerShell 兼容 cmd 命令):
# 假设脚本位于当前目录hello.bat# 或使用完整路径(推荐,避免路径空格问题).\hello.bat⚠️ 注意:若脚本名含空格或特殊字符,务必用引号包裹,并加 .\ 前缀(PowerShell 中尤其重要,否则会被误判为命令而非文件)。
PowerShell 脚本(.ps1)
PowerShell 因其强大的对象管道与系统管理能力成为 Windows 自动化的首选。但默认受严格执行策略(Execution Policy)限制:
# 查看当前策略(以管理员身份运行终端才能修改)Get-ExecutionPolicy# 常见策略:Restricted(默认,禁止运行脚本)、RemoteSigned(本地脚本可运行,远程需签名)、AllSigned、Unrestricted # 开发者常用(仅当前用户生效,无需管理员):Set-ExecutionPolicy RemoteSigned -Scope CurrentUser运行方式:
.\script.ps1 # 必须带 .\ 前缀(防命名冲突)# 或使用全路径C:\Scripts\deploy.ps1Python 脚本(.py)
前提:已安装 Python 并配置至系统 PATH(可通过 python --version 验证)。
# 推荐使用 python(兼容 Python 2/3)或 python3(明确指定)python script.pypython3 main.py# 若脚本首行含 shebang(如 #!/usr/bin/env python3),在 WSL 中可直接 ./script.py;Windows 下通常忽略该行💡 提示:建议使用虚拟环境(python -m venv myenv → myenv\Scripts\activate.bat)隔离依赖。
Node.js 脚本(.js)
确保已安装 Node.js(node -v 可查)。运行方式极简:
node app.jsnode index.mjs # ES 模块需 .mjs 后缀或 package.json 中 "type": "module"Bash 脚本(.sh)——通过 WSL
启用 WSL 后,在 Windows 终端中新建标签页选择 “Ubuntu”(或其他发行版),即可像 Linux 一样操作:
# 赋予执行权限(关键!Windows 文件系统默认无 x 权限)chmod +x deploy.sh./deploy.sh# 或直接解释器调用(绕过权限检查)bash deploy.sh📌 小技巧:WSL 中可通过 /mnt/c/Users/Name/... 访问 Windows 文件,但建议将项目放在 Linux 文件系统(如 ~/projects/)以获最佳性能与权限支持。
关键注意事项与最佳实践
编码问题:Windows 默认 ANSI(GBK),而 UTF-8 是现代标准。PowerShell 6+ 默认 UTF-8,但旧版 cmd 显示中文可能乱码。解决方案:在脚本开头添加 chcp 65001(切换代码页为 UTF-8),或统一用 VS Code 等编辑器保存为 UTF-8 with BOM(对 .ps1 更友好)。
路径分隔符:Windows 用 \,Linux/macOS 用 /。脚本跨平台时,优先使用 /(PowerShell 和 cmd 均兼容),或用语言内置函数(如 Python 的 os.path.join()、PowerShell 的 Join-Path)。
安全第一:切勿随意执行来源不明的 .ps1 或 .bat;下载脚本后先用 Get-Content script.ps1 | more 审阅内容;生产环境避免 Set-ExecutionPolicy Unrestricted。
调试技巧:PowerShell 中加 Set-PSDebug -Trace 1;Python 加 -v 参数;所有脚本建议以 echo "Script started at $(Get-Date)" 开头,便于日志追踪。
:让脚本成为您的数字助手
Windows 终端已彻底告别“黑框时代”。掌握脚本运行机制,不仅是技术能力的体现,更是提升日常效率、实现 DevOps 自动化、构建个人知识工作流的基石。从一个简单的 backup.bat 到复杂的 CI/CD 流水线,每一步都始于终端中敲下的那条命令。请记住:真正的力量不在界面有多炫,而在你能否用寥寥数行代码,驯服复杂,释放时间。 现在,打开 Windows Terminal,创建你的第一个 .ps1 文件,输入 Write-Host "Hello, Automated World!",然后按下回车——自动化之旅,就此启程。
(全文约1580字)






