更新本地项目到最新git版本脚本

由于平时工作中项目较多,每天刚上班都需要更新一下项目代码,一个一个更新感觉稍微麻烦了一些,所以写了一个简单的shell脚本,每天到公司先执行一遍即可。

bash 复制代码
#!/bin/bash

# 进入指定的目录
target_dir="$1";
cd "$target_dir";
echo "当前工作目录:$target_dir";
# 列出所有目录
echo "========================== 待更新目录 ==========================";
ls -l;
echo -e "\n"

## 所有目录名称push进数组

# 循环索引
c=0;
for file in `ls`
do
  filelist[$c]=$file
  c=`expr $c + 1`
done

## 遍历数组并执行git命令

# 计数
num=0;
for i in ${filelist[@]};
do {
    # 更新目录
    git_dir="$target_dir/$i"
    cd "$git_dir"
    if [[ -e ".git" ]]; then
        # 执行 git pull 命令
        echo -e "\n"
        echo "开始更新 $git_dir 项目..."
        git pull
        echo "$git_dir 项目更新完成"
        num=`expr $num + 1`
        echo -e "\n"
    else
        echo "$i 不是 git 目录";
        echo -e "\n"
    fi
}
done

# 获取数组总长度
length=${#filelist[@]}
echo -e "\n"
echo "该目录下文件(夹)总数:$length"
echo -e "\n"
echo "========================== 本次共更新了 $num 个 Git项目 =========================="

思路很简单,输入想要更新的父目录,ls列出当前目录下所有文件夹,挨个遍历其中的每个文件夹,如果文件夹内包含.git文件,认为该文件夹是个git目录,然后执行git pull命令更新。

使用方式

sh gittask.sh "/workspace"

./gittask.sh "/workspace"

如果当前目录是想要更新的父目录,则可以

pwd | xargs sh gittask.sh

使用效果如下

相关推荐
春夜喜雨2 小时前
Git 分支merge合并常用步骤与命令操作
git
秦时明月之君临天下2 小时前
Git查看分支创建时间
git
liuxin_07253 小时前
phpstorm 操作git 分支合并到master
ide·git·phpstorm
cyforkk5 小时前
Git 进阶技巧:优雅合并初始提交与 Commit 规范详解
git
Elcker5 小时前
修改Git指定提交作者与时间
git
❀͜͡傀儡师6 小时前
Apifox投毒事件深度分析报告:供应链攻击窃取SSH密钥与Git凭据
git·ssh·apifox
云梦谭7 小时前
Git 环境定制常用命令
git
SuperEugene7 小时前
前端 Git 协作规范实战:commit message + 分支管理 + 合并流程,告别冲突与混乱|工程化与协作规范篇
前端·javascript·vue.js·git·前端框架
bu_shuo8 小时前
git中文显示不正确解决方法
git
Carsene8 小时前
艺术化你的 Git 提交:类型与图标(全网最全)的实践准则
git·github