如果我修改了版本控制文件的几行,是否可以通过命令行撤消对一行的更改?
就像我对整个文件所做的那样:
git checkout /path/to/file.extension
但做类似的事情,说
git checkout /path/to/file.extension --line 10
这可能吗?
如果我修改了版本控制文件的几行,是否可以通过命令行撤消对一行的更改?
就像我对整个文件所做的那样:
git checkout /path/to/file.extension
但做类似的事情,说
git checkout /path/to/file.extension --line 10
这可能吗?
您可以使用git checkout -p
单独查看每个大块并决定是检查它们还是保持原样(如果您想进一步缩小范围,这也需要一个可选的路径参数)。
要详细说明马特的答案,git checkout --patch -- <path argument>
请使用以下选项启动交互模式:
y - stage this hunk
n - do not stage this hunk
q - quit; do not stage this hunk or any of the remaining ones
a - stage this hunk and all later hunks in the file
d - do not stage this hunk or any of the later hunks in the file
g - select a hunk to go to
/ - search for a hunk matching the given regex
j - leave this hunk undecided, see next undecided hunk
J - leave this hunk undecided, see next hunk
k - leave this hunk undecided, see previous undecided hunk
K - leave this hunk undecided, see previous hunk
s - split the current hunk into smaller hunks
e - manually edit the current hunk
? - print help
y
n
s
和选项是一个很好的e
起点。
也可以看看: