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

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

相关推荐
hollyhuang17 分钟前
正则校验:校验只能输入数字且首位不能是0
前端
一室易安19 分钟前
模仿elementUI 中Carousel 走马灯卡片模式 type=“card“ 的自定义轮播组件 图片之间有宽度
前端·javascript·elementui
脸大是真的好~28 分钟前
黑马JAVAWeb -Vue工程化 - Element Plus- 表格-分页条-中文语言包-对话框-Form表单
前端·javascript·vue.js
一个小潘桃鸭31 分钟前
记录:echarts tooltip内容过多时,会导致部分内容遮挡
前端
小满zs41 分钟前
Next.js第四章(路由导航)
前端
进击的野人43 分钟前
深入理解 CSS4 新特性:CSS 变量
前端·css
DevUI团队44 分钟前
🚀 MateChat发布V1.10.0版本,支持附件上传及体验问题修复,欢迎体验~
前端·vue.js·人工智能
用户345848285051 小时前
Vue是怎么实现双向绑定的
前端
彩虹下面1 小时前
手把手带你阅读vue2源码
前端·javascript·vue.js
华洛1 小时前
经验贴:Agent实战落地踩坑六大经验教训,保姆教程。
前端·javascript·产品