Shell-语言导致的小问题

主要背景

临时接到一个需求,需要批量更换若干个项目中的package.json某个包的版本,这个好说,梳理下,不多就几个,直接npm i xxx -D。接下来就是需要打包了,部署测试以及生产环境了。

但是在想一个问题,现在是几个,如果后面是几十个甚至上百个怎么办,难道一个个去更新?,那估计要累死。于是准备写一个脚本。在这里,Mac真好用,这也是我为社么从Windows换到Mac的原因之一。

新建脚本

bash 复制代码
#!/bin/bash

# 进入目录
cd xxx

modified_dirs=($(git status | grep "modified:" | awk '{print $2}' | xargs -I {} dirname {} | sort | uniq))

# 打印分割后的数据
for i in "${modified_dirs[@]}"; do
    # 进入具体的项目目录
    cd $i
    # 执行脚本命令
    npm run xxx
    # 切到上级目录
    cd ..
done

内容不多,就上面这些,然后就开始测试了。于是于是,就有了问题

测试过程

首先是在vscode里面进行测试的,一切都很正常,正常执行命令,正常打包,然后的然后,准备在电脑终端上执行,问题的开始,总是不执行,莫名其妙,明明开发工具中可以执行,为啥这里不能执行。

首先,有几个先决条件要满足

  1. 脚本得有执行的权限
  2. 当前用户得有脚本的执行权限

说白了,权限、权限、权限

然后开始对比vscode脚本中的输出,看看有什么不同的

vscode

脚本

好了,恍然大悟。

解决办法

修改.zshrc文件,添加一行

bash 复制代码
export LANG=en_US.UTF-8

然后退出保存source .zshrc

在这么继续执行下去就好了,就这么中英文切换的问题,卡壳的半天。

相关推荐
锋行天下25 分钟前
如何用Vite实现Vue组件的按需打包和远程加载
前端·vue.js·前端框架
光影少年42 分钟前
原生DOM操作在React 中的注意事项
前端·javascript·react.js
禅思院3 小时前
前端部署“三层漏斗”完全指南:从CI/CD到自动回滚的工程化实战【开题】
前端·架构·前端框架
快乐肚皮3 小时前
深入理解Loop Engineering
前端·后端
风骏时光牛马4 小时前
VHDL十大经典基础功能设计实例代码合集
前端
hunterandroid4 小时前
Notification 通知:从基础到渠道适配
前端
孟陬4 小时前
Claude Code 巧思 `Ctrl+S` 暂存键
前端·后端
PedroQue994 小时前
V1.6.1性能优化:高频路径提速与代码精简
前端·uni-app
猩猩程序员4 小时前
将 LiteLLM 迁移到 Rust —— 构建最快、最轻量的 AI Gateway
前端
lichenyang4535 小时前
JSBridge 分发升级:为什么要从 if-else 变成 Registry > 这是「ASCF 架构升级」系列的第 3 篇
前端