我有两个分支(A和B),我想合并来自分支A的单个文件与来自分支B的相应单个文件。
当前回答
假设B是当前分支:
$ git diff A <file-path> > patch.tmp
$ git apply patch.tmp -R
注意,这只对本地文件应用更改。之后你需要做出承诺。
其他回答
我将这样做
Git format-patch branch_old..branch_new文件
这将为文件生成一个补丁。
在目标branch_old上应用补丁
去吧等等补丁
你可以用:
git merge-file
提示:https://www.kernel.org/pub/software/scm/git/docs/git-merge-file.html
下面的命令将 (1)比较文件的正确分支,以掌握 (2)交互式地询问您应用哪些修改。
git checkout --patch master <fn>
下面是我在这种情况下的做法。这是一个拼凑,但它对我来说很好。
在工作分支的基础上创建另一个分支。 git pull/git合并修订版(SHA1),其中包含您想要复制的文件。这将合并所有的更改,但我们只使用这个分支来获取一个文件。 解决任何冲突等调查你的文件。 检出您的工作分支 签出合并提交的文件。 提交它。
我试过修补,但我的情况太糟糕了。简而言之就是这样的
工作部门:A 实验分支:B(包含文件.txt,其中有我想折叠的变化)
git checkout A
根据A创建新分支:
git checkout -b tempAB
将B合并为tempAB
git merge B
复制合并的sha1哈希值:
git log
commit 8dad944210dfb901695975886737dc35614fa94e
Merge: ea3aec1 0f76e61
Author: matthewe <matthewe@matthewe.com>
Date: Wed Oct 3 15:13:24 2012 -0700
Merge branch 'B' into tempAB
签出你的工作分支:
git checkout A
签出您修复的文件:
git checkout 7e65b5a52e5f8b1979d75dffbbe4f7ee7dad5017 file.txt
你应该知道了。提交你的结果。
我发现这种方法简单而有用:如何“合并”来自另一个分支的特定文件
事实证明,我们太努力了。我们的好朋友git checkout是完成这项工作的合适工具。 Git checkout source_branch <paths>… 我们可以简单地给git checkout特性分支A的名称和我们想要添加到主分支的特定文件的路径。
为了更好的理解,请阅读全文
推荐文章
- 为什么我需要显式地推一个新分支?
- 如何撤消最后的git添加?
- Rubymine:如何让Git忽略Rubymine创建的.idea文件
- 如何合并字典的字典?
- Gitignore二进制文件,没有扩展名
- Git隐藏错误:Git隐藏弹出并最终与合并冲突
- 了解Git和GitHub的基础知识
- 没有。Git目录的Git克隆
- 在GitHub上有一个公共回购的私人分支?
- Git与Mercurial仓库的互操作性
- 忽略git中修改(但未提交)的文件?
- “git restore”命令是什么?“git restore”和“git reset”之间有什么区别?
- Git合并与强制覆盖
- Git拉另一个分支
- 在Bash命令提示符上添加git分支