linux中使用git获取所有分支,并获取所有分支中的logs然后输出保存为diff文件

c 复制代码
#!/bin/bash

# 创建目录用于存储每个分支的文件
mkdir branches

# 获取所有分支
branches=$(git branch -a)

# 遍历所有分支
for branch in $branches; do
  # 在每个分支上切换
  git checkout $branch
  
  # 使用git log --oneline将日志附加到all.log文件
  git log --oneline > all.log

  # 获取分支名
  branch_name=$(echo $branch | awk -F'/' '{print $NF}')

  # 创建分支文件夹
  mkdir "branches/$branch_name"

  # 遍历all.log文件的所有日志
  while read -r line; do
    # 解析每一行的id和name
    id=$(echo $line | awk '{print $1}')
    name=$(echo $line | awk '{print $2}')

    # 在分支文件夹下创建以name为文件名的.diff文件
    touch "branches/$branch_name/$name.diff"

    # 在.diff文件中写入相应的内容,这里只是一个示例
    echo "Changes for $name (ID: $id)" >> "branches/$branch_name/$name.diff"
    git diff $id >> "branches/$branch_name/$name.diff"
  done < all.log
done
相关推荐
Ghost Face...5 小时前
Linux音频控制神器:amixer完全指南
linux·chrome·音视频
大柏怎么被偷了5 小时前
【Linux】进程替换
linux·运维·服务器
EAIReport5 小时前
企业级报表自动化:基于Docker的部署实践
运维·docker·自动化
happyCoder5 小时前
VS Code Git 神器:内置功能与GitLens插件使用技巧
git·github
Xの哲學5 小时前
Linux 指针工作原理深入解析
linux·服务器·网络·架构·边缘计算
乌萨奇也要立志学C++5 小时前
【Linux】进程信号(二)信号保存与捕捉全解析、可重入函数、volatile
linux·服务器
小番茄夫斯基6 小时前
深入解析 git merge 和 git rebase 的区别
git
不会写程序的未来程序员6 小时前
详细的 Git 操作分步指南
大数据·git·elasticsearch
行初心6 小时前
uos基础 sys-kernel-debug.mount 查看mount文件
运维
芒鸽6 小时前
高效团队协作的基石:Git流程规范详解
git