Github fork项目后如何拉取其他分支

【前言】我们在Github里fork了一个仓库后会发现自己的仓库里只有一个分支,就是源仓库的主分支,这个时候我们想在其他分支上贡献代码,应该怎么办呢?因为有时候我们可能会想把修改同步到多个分支。

查看当前分支:

git branch -a

 

该仓库的主分支为release/2.6,此时我已经切换到了develop分支

可以看到远程分支分为origin和upstream两种,origin即为我们的仓库,upstream即为上游仓库

直接切到develop的话会拉取上游仓库的分支,如图:

所以我们需要手动的把develop分支拉取到我们的仓库,怎么拉呢?

先把upstream的分支拉到本地,再推送到origin仓库

  

上面我已经把develop分支拉到了本地,这里直接推送:

git push origin develop

可以看到推送完之后自动在远程仓库创建了一个develop分支

再次查看分支:

 此时多了一个origin/develop分支,这就是我们刚才创建的分支。

但此时本地的develop分支跟踪的还是upstream仓库的分支,是没有权限推送的,所以还需要修改一下develop跟踪的分支,使用-u选项:

$ git branch -u origin/develop

或者把本地的develop分支删掉,重新拉取origin的分支

之后就可以往origin仓库推送,并向upstream仓库的develop分支提PR了。
 

### 如何在GitHub上进行fork操作 #### 创建Fork 当希望基于他人的项目创建自己的版本而不影响原项目时,可以使用Fork功能。通过点击目标仓库页面右上方的"Fork"按钮来启动此过程[^1]。 ```bash # 假设已经登录到GitHub账户 # 找到想要分叉的目标仓库主页 # 页面顶部右侧有明显的 "Fork" 按钮 ``` #### Clone Fork后的仓库至本地环境 完成上述步骤后,在个人账号下的新复制版库中会看到该项目副本。此时可将其克隆下来以便于本地开发: ```bash git clone https://github.com/YourUsername/ForkedRepo.git cd ForkedRepo ``` #### 设置上游远程地址并与之同步更新 为了能够获原始项目的最新改动,需配置指向源仓库的远端连接,并定期最新的变更记录: ```bash # 添加名为 'upstream' 的远程链接指向官方主仓 git remote add upstream https://github.com/OriginalAuthor/OriginalRepo.git # 查看当前已设置的所有远程路径确认无误 git remote -v # 获来自上级资源库的数据流但不自动合并入工作区 git fetch upstream # 将抓的内容整合进指定分支内(通常为主干master) git merge upstream/master # 或者采用更简洁的一键式同步方式 git pull upstream master ``` #### 提交Pull Request贡献代码改进 经过一系列编辑调整之后准备向初始作者发起请求审核所作变动,则按照如下流程执行: ```bash # 创立新的特性专题分支开展具体任务前 git checkout -b feature-branch-name # 完成编码作业后再切换回默认发布线路上做最终集成测试 git checkout main || git checkout master # 把特色子项里的成果纳入主线之中去 git merge feature-branch-name # 推送到云端服务器等待他人审阅反馈意见 git push origin HEAD ``` 最后一步就是在网页界面上找到对应位置提交PR给维护人员评估是否采纳这些变化了[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值