git 如何 fork 一个仓库的所有分支

今天在Github上看到一个不错的开源项目,准备研究一下,于是用fork操作。

结果默认fork只会将当前选择的分支fork下来。

但是我想fork所有分支,后面可以切换不同的分支,达到"完全"fork所有分支的效果。

搜索了几篇文章,跟着一顿操作下来不顶用,于是询问大模型得到了这篇,自己亲自验证了可行,整体步骤相对简单。

在 Git 中 fork 仓库并获取所有分支的操作步骤如下:

1. 在代码平台上完成 Fork

首先在你的 GitHub/GitLab 等平台上点击 "Fork" 按钮,将仓库复制到你的账户下。

2. 克隆 Fork 的仓库到本地

bash 复制代码
git clone https://github.com/你的用户名/仓库名.git
cd 仓库名

3. 添加上游仓库地址

bash 复制代码
git remote add upstream https://github.com/原仓库所有者/仓库名.git

4. 获取上游仓库所有分支

bash 复制代码
git fetch upstream

5. 查看所有远程分支

bash 复制代码
git branch -a  # 会显示 upstream/分支名

6. 批量创建本地分支跟踪所有远程分支

一键完成所有分支同步:

bash 复制代码
git branch -r | grep -v '\->' | while read remote; do 
    git branch --track "${remote#upstream/}" "$remote"
done
git fetch --all
git pull --all

或手动逐个创建:

bash 复制代码
git checkout -b 分支名 upstream/分支名

7. 推送所有分支到你的 Fork

bash 复制代码
git push origin --all

完整脚本(推荐)

将以下保存为 sync-fork.sh 并执行:

bash 复制代码
#!/bin/bash
git fetch upstream
git branch -r | grep 'upstream/' | grep -v HEAD | while read branch; do
    local_branch="${branch#upstream/}"
    git show-ref --verify --quiet refs/heads/$local_branch || \
    git branch --track $local_branch $branch
done
git pull --all
git push origin --all
git push origin --tags

关键说明

  • --all 参数可一次性操作所有分支
  • --track 建立本地分支与远程分支的跟踪关系
  • 后续更新所有分支只需运行:git pull --all

这样就能在你的 Fork 中拥有原仓库的所有分支了!

相关推荐
弘毅 失败的 mian41 分钟前
Git 分支管理
大数据·经验分享·笔记·git·elasticsearch
NEXT061 小时前
从Git三连到时光机大师:我的代码终于有了后悔药
git
✎ ﹏梦醒͜ღ҉繁华落℘1 小时前
软件版本管理 SVN 和 Git
git·svn
安当加密2 小时前
数据库密码还在 Git 里?用 SMS凭据管理系统实现生产/开发环境隔离
数据库·git
Irene19912 小时前
实用篇:vsCode 中连接 WSL 并快速开始一个 Vue3 新项目
git·vscode·vue·wsl
笔夏2 小时前
【安卓学习之myt】git常用命令
android·git
陌影-3 小时前
vite+vue3项目配置git commit提交
git
弘毅 失败的 mian4 小时前
Git 远程操作
经验分享·笔记·git
wdfk_prog15 小时前
Git实战指南:如何从另一个分支同步文件时完整保留Commit提交历史
git
In_life 在生活15 小时前
GIT stash 命令的使用
git