如何在Git中执行以下操作?

我当前的分支是branch1,我做了一些本地更改。 但是,我现在意识到我实际上是要将这些更改应用于branch2。 有没有办法应用/合并这些更改,以便它们成为branch2上的本地更改而不在branch1上提交它们?


#1楼

到目前为止给出的答案并不理想,因为它们需要大量不必要的工作来解决合并冲突,或者它们做出太多假设,这些假设经常是错误的。 这是如何做到完美。 该链接指向我自己的网站。

如何在git中提交不同的分支

您在my_branch上有未提交的更改要提交给master ,而不提交my_branch所有更改。

git merge master
git stash -u
git checkout master
git stash apply
git reset
git add example.js
git commit
git checkout .
git clean -f -d
git checkout my_branch
git merge master
git stash pop

说明

首先将master合并到您的分支中,因为无论如何您最终都必须这样做,现在是解决任何冲突的最佳时机。

git stash -u-u选项(又名--include-untracked )可以防止你以后在master执行git clean -f -d时丢失未跟踪的文件。

git checkout master ,重要的是你不要git stash pop ,因为你以后需要这个存储。 如果你弹出在my_branch创建的存储,然后在master执行git stash ,当你稍后在my_branch应用该存储时,将导致不必要的合并冲突。

git reset unstages由git stash apply产生的一切。 例如,已经在存储中修改但在master不存在的文件将被暂存为“由我们删除”冲突。

git checkout . 和git clean -f -d丢弃未提交的所有内容:对跟踪文件的所有更改以及所有未跟踪的文件和目录。 它们已经保存在存储中,如果留在master ,在切换回my_branch时会导致不必要的合并冲突。

最后一个git stash pop将基于原始的my_branch ,因此不会导致任何合并冲突。 但是,如果您的存储包含您已提交掌握的未跟踪文件,git会抱怨它“无法从存储中恢复未跟踪的文件”。 要解决此冲突,请从工作树中删除这些文件,然后git stash pop , git add . ,和git reset 。


#2楼

前面提到的藏匿方法的一个较短的替代方案是:

暂时将更改移动到存储区。

  1. git stash

创建并切换到新分支,然后只需一步即可将存储区弹出。

  1. git stash branch new_branch_name

然后只需add更改并将更改commit到此新分支。


#3楼

警告:不适用于git新手。

这在我的工作流程中已经足够了,我几乎试图为它编写一个新的git命令。 通常的git stash流程是要走的路, 有点尴尬。 我通常先做一个新的提交,因为如果我一直在查看更改,所有的信息都是我脑海中的新鲜事,最好只是启动git commit -ing我发现的东西(通常是我在工作时发现的属于master的bugfix)在功能分支上)马上。

它也很有用 - 如果你经常遇到这样的情况 - 在你当前的工作目录旁边有一个总是有master分支签出的工作目录 。

所以我如何实现这一点是这样的:

  1. git commit使用良好的提交消息立即git commit更改。
  2. git reset HEAD~1撤消当前分支的提交。
  3. (可选)继续处理该功能。

有时候稍后(异步),或者立即在另一个终端窗口中:

  1. cd my-project-master这是另一个WD共享相同的.git
  2. git reflog找到我刚刚创建的bugfix。
  3. git cherry-pick SHA1的提交。

(可选)(仍然是异步的)您可以重新绑定(或合并)您的功能分支以获取错误修正,通常在您即将提交PR并已清理您的功能分支和WD时:

  1. cd my-project这是我正在研究的主要WD。
  2. git rebase master来获取错误修正。

通过这种方式,我可以不间断地继续处理该功能,而不必担心git stash任何东西或者必须在git checkout之前清理我的WD(然后再次检查功能分支退出。)并且仍然拥有我的所有错误修正转到master而不是隐藏在我的功能分支中。

当您处理一些重要功能时,IMO git stashgit checkout是一个真正的PIA。


#4楼

如果它是关于承诺的更改,你应该看看git-rebase,但正如VonC在评论中指出的那样,当你谈论本地更改时,git-stash肯定是这样做的好方法。


#5楼

由于您的文件尚未在branch1branch1 :

git stash
git checkout branch2
git stash pop

要么

git stash
git checkout branch2
git stash list # to check the various stash made in different branch
git stash apply x # to select the right one

由benjohn 评论 (参见git stash手册页 ):

要隐藏当前未跟踪(新添加的)文件,请添加参数-u ,以便:

git stash -u

来源:站长资讯平台

如何将本地未提交的更改合并到另一个Git分支?的更多相关文章

  1. git reset之后找回本地未提交的代码

    头脑发热使用了git reset命令回退到了之前的一个版本,结果把本地没有提交的代码给覆盖掉了..... 作为一个bug员自然是想恢复,毕竟重新写还得再测一遍,本着能懒一点是一点的原则,开始了恢复代码 ...

  2. git撤销本地所有未提交的更改

    1. git clean -df2. git reset --hard第一个命令只删除所有untracked的文件,如果文件已经被tracked, 修改过的文件不会被回退.而第二个命令把tracked ...

  3. git如何删除本地所有未提交的更改

    stash很好用,至少不会影响 .gitignore 里面的不跟踪的文件: git add . && git stash && git stash drop ===== ...

  4. 如何导入另一个 Git库到现有的Git库并保留提交记录

    问题描述: 我在本地有两个Git库项目(D1=PC项目 包含通用项目,D2=移动项目 也包含通用项目这两个项目在同一目录下),因为这两个项目使用的通用项目是一样的如数据库访问等   只有显示层(vie ...

  5. Git分支合并冲突解决

    前2天群里发了张git历史图,如下: 根据提交历史,可以看出图中所有分支合并都采用merge的方式,具体merge是怎么操作的,可以阅读下边文章. 根据项目上的需求,如果要求git提交历史是比较简单的 ...

  6. Git本地有未提交文件,直接拉取远端最新版本

    git pull = git fetch + git merge 1.修改不同的文件: 用户D和用户L在本地提交中修改了不同的文件,如果用户D将改动推送到服务器后,用户L再推送就会遇到非快进式推送错误 ...

  7. 【IntelliJ IDEA】在idea上操作 git分支合并【如何将远程swagger分支 合并到 远程 master分支上】【如何切换 本地分支】

    ============================================ 明确一点: 如果项目交给git管理了[如何将项目交给git管理:https://www.cnblogs.com ...

  8. GIT 如何删除某个本地的提交

    一.rm后要commit一下才会生效,但这样只是让文件不再出现在今后的版本中,文件副本仍然会在.git/下(这样git才能让误删的文件恢复). 要彻底消灭文件副本,那就要让文件彻底从历史中消失,分两种 ...

  9. Git分支操作——查看、新建、删除、提交、合并

    查看分支 1 查看本地分支 $ git branch   2 查看远程分支 $ git branch -r     创建分支 1 创建本地分支 $ git branch branchName 2 切换 ...

随机推荐

  1. jquery获取高度

    分为以下几种: .height() -获取匹配元素集合中的第一个元素的当前计算高度值 或 设置每一个匹配元素的高度值. -.css('height') 和 .height()之间的区别是后者返回一个没 ...

  2. java课程之团队开发冲刺阶段2.4

    总结昨天进度: 1.照例学习了课前提醒的功能,不可否认的是,在这个功能上,需要的技术和之前的上课静音有点相似,都是通过广播然后开启service服务,然后进行每分钟的监听,查看时间是否一致,在一致的情 ...

  3. Day 8:方法上自定义泛型、类上、接口上、泛型的上下限

    泛型 泛型是jdk1.5使用的新特性  泛型的好处:   1. 将运行时的异常提前至了编译时    2. 避免了无谓的强制类型转换 泛型在集合中的常见应用:    ArrayList<Strin ...

  4. POJ - 1742 Coins(dp---多重背包)

    题意:给定n种硬币的价值和数量,问能组成1~m中多少种面值. 分析: 1.dp[j]表示当前用了前i种硬币的情况下,可以组成面值j. 2.eg: 3 10 1 3 4 2 3 1 (1)使用第1种硬币 ...

  5. Tensorflow学习教程------利用卷积神经网络对mnist数据集进行分类_利用训练好的模型进行分类

    #coding:utf-8 import tensorflow as tf from PIL import Image,ImageFilter from tensorflow.examples.tut ...

  6. SpringCloud学习之Bus消息总线实现配置自动刷新(九)

    前面两篇文章我们聊了Spring Cloud Config配置中心,当我们在更新github上面的配置以后,如果想要获取到最新的配置,需要手动刷新或者利用webhook的机制每次提交代码发送请求来刷新 ...

  7. Q9:Palindrome Number

    9. Palindrome Number 官方的链接:9. Palindrome Number Description : Determine whether an integer is a pali ...

  8. 68.ORM查询条件:date,time,year,week_day等

    1. date: 首先查看数据库中article表的信息,由表中的create_time字段可以看出时间为2020.2.5 打印出查询的结果: <QuerySet []>:但是查询的结果为 ...

  9. JavaWeb之Servlet入门(一)

    1. Servlet介绍 Servlet(Server Applet),全称Java Servlet,是用Java编写的服务器端程序.其主要功能在于交互式地浏览和修改数据,生成动态Web内容. 2. ...

  10. 动态类型识别&动态创建

    以下大部分内容摘自<windows程序设计 第2版> 王艳平 张铮 编著 动态类型识别:在程序运行过程中,辨别对象是否属于特定类的技术. 应用举例:函数辨别参数类型.需要针对对象的类编写特 ...