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

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

相关推荐
o***Z44825 分钟前
前端无障碍开发检查清单,WCAG合规
前端
J***Q2921 小时前
前端CSS架构模式,BEM与ITCSS
前端·css
G***T6911 小时前
React性能优化实战,避免不必要的重渲染
前端·javascript·react.js
q***d1731 小时前
前端微前端部署方案,Nginx与Webpack
前端·nginx·webpack
y***54882 小时前
前端构建工具扩展,Webpack插件开发
前端·webpack·node.js
4***14902 小时前
前端构建工具多页面配置,Webpack与Vite
前端·webpack·node.js
网络点点滴2 小时前
标签的ref属性
前端·javascript·vue.js
天若有情6732 小时前
前端 vs 后端:入行软件行业,我该如何选择?哪个更“简单”?
前端·后端·软件开发·职业·就业·选择
小画家~2 小时前
第二十八:golang Time.time 时间格式返回定义结构体
java·前端·golang
Cobyte3 小时前
17. Vue3 业务组件库按需加载的实现原理
前端·javascript·vue.js