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

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


当前回答

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

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

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

其他回答

如上面的一个答案所示,您可以使用git add--补丁文件名.txt

或简称git add-p文件名.txt

…但对于存储库中已经存在的文件,在s中,直接在commit命令上使用--patch标志要好得多(如果您使用的是足够新的git版本):gitcommit--补丁文件名.txt

…或者,再次,简称gitcommit-p文件名.txt

…然后使用上述键(y/n等)选择要包含在提交中的行。

您可以使用gitadd--interactive或gitadd-p<file>,然后使用gitcommit(而不是gitcommit-a);请参阅gitadd手册页中的交互模式,或简单地按照说明进行操作。

现代Git还提供了gitcommit——交互式(和gitcommit补丁,这是交互式提交中补丁选项的快捷方式)。

如果您喜欢从GUI执行,可以使用gitgui。通过右键单击并选择以下选项,您可以简单地标记要包含在提交中的块:

为提交准备Hunk

如果您只想添加大块的某些行,也可以选择所需的行,右键单击它们,然后:

提交的暂存行

我个人觉得这比使用git add-I更容易。其他git GUI,如Qbit或GitX,也可能具有此功能。

如果你碰巧在使用VS代码,那你就幸运了。选择要暂存的范围,然后使用Git:Sstage Selected Ranges暂存它们,如果需要,请提交。

我录制了一张gif图来演示我的意思:

我强烈建议使用Atlassian的SourceTree。(这是免费的。)这让事情变得微不足道。您可以快速轻松地分段单个大块代码或单个代码行。

我相信git add-e myfile是最简单的方法(至少是我的首选),因为它只需打开一个文本编辑器,让您选择要暂存的行和不暂存的行。关于编辑命令:

添加的内容:

添加的内容由以“+”开头的行表示。您可以通过删除添加行来防止暂存任何添加行。

删除的内容:

删除的内容由以“-”开头的行表示。通过将“-”转换为“”(空格),可以防止临时删除它们。

修改内容:

修改后的内容由“-”行(删除旧内容)和“+”行(添加替换内容)表示。您可以通过将“-”行转换为“”并删除“+”来防止暂存修改线请注意,仅修改其中的一半可能会对索引带来混乱的变化。

git-add的所有细节都可以在git-help-add上找到