当我对Git中的文件进行更改时,如何才能只提交部分更改?

例如,如何在文件中更改的30行中只提交15行?


当前回答

使用TortoiseGit:

右键单击文件并使用上下文菜单→ 提交后恢复。这将按原样创建文件的副本。然后您可以编辑该文件,例如在TortoiseGitMerge中,并撤消所有不想提交的更改。保存这些更改后,您可以提交文件。

其他回答

就像jdsumsion的答案一样,你也可以隐藏你当前的工作,但然后使用像meld这样的困难工具从隐藏中提取所选的更改。这样,您甚至可以非常容易地手动编辑大块,这在gitadd-p中有点麻烦:

$ git stash -u
$ git difftool -d -t meld stash
$ git commit -a -m "some message"
$ git stash pop

如果代码仍然有效,那么使用stash方法可以在提交之前进行测试。

git-cola是一个很棒的GUI,并且内置了这个功能。只需选择要分段的行,然后按S。如果没有选择,则将分段完整的大块。

vim-gitgolf插件可以在不离开vim编辑器的情况下使用

:GitGutterStageHunk

除此之外,它还提供了其他很酷的功能,如一些现代IDE中的差异符号列

如果只有一部分人被安排逃亡

:Gdiff

允许视觉范围选择,然后:“<,”>diffput或:“<”>diffget暂存/还原单个行更改。

在所有这些工具中,我最喜欢Fork(虽然不是免费的)!

与其他游戏相比,它使用起来非常时尚优雅,单击鼠标旁边的按钮可以进行大块或线条分段。

另一个选择是GitKraken,有趣但更复杂和强大!

git meld索引--引用自网站:

git-meld-index运行meld——或任何其他gitdifftool(kdiff3、diffuse等)——允许您以交互方式将更改转移到git索引(也称为git暂存区)。

这与git add-p和git add-interactive的功能类似。在某些情况下,meld比gitadd-p更容易/更快使用。这是因为meld允许你,例如:

查看更多上下文参见行内差异手动编辑并查看“实时”差异更新(每次按键后更新)导航到更改,而不必对要跳过的每个更改说“n”

用法

在git存储库中,运行:

git meld-index

您将看到meld(或您配置的gitdifftool)弹出:

左:从工作树复制的临时目录连续文件

RIGHT:包含索引内容的临时目录。这还包括尚未在索引中但在工作副本中已修改或未跟踪的文件——在本例中,您将从HEAD中看到文件内容。

编辑索引(右手边)直到满意。记得在需要时保存。

完成后,关闭meld,git meld索引将更新索引,以匹配刚刚编辑的meld右侧临时目录的内容。