方法:1、用「git commit --amend」指令修改一次歷史記錄;2、用「git rebase -i 指定提交號碼」指令修改多個歷史記錄;3、用「git filter- branch --filer 指令修改的範圍」指令重寫歷史記錄。
本文操作環境:Windows10系統、Git2.30.0版、Dell G3電腦。
git怎麼修改歷史記錄
#初級選手git amend
如果只是在提交之後發現自己手殘了,用git commit --amend就可以修改剛才的那次提交。該命令在執行以後,會將剛剛的那一次提交從當前分支移除,把工作空間恢復到上次準備提交的狀態(同時混合了上次提交之後的更改),然後顯示出一個vim 的界面讓你去修改上次的提交資料。在vim 中儲存後,就會把目前的所有修改一併用新的提交資訊提交了。
該指令僅可以修改最後一次提交,一個指令相當於執行如下一系列動作:
$ORIG_HEAD=`git show`#保存当前的这次提交的 commit 号 $git reset --soft HEAD^#回到最后一次提交准备提交前的状态 $...#做一些操作和修改 $git commit -c $ORIG_HEAD#表示用最后一次提交的提交信息来做为提交信息,不过会调出编辑器界面
中級選手git rebase
##前面的git commit --amend僅僅可以修改最後一次提交,但是當自己一時興起,手殘了一路時,這個命令就無法拯救我們了,這個時候我們就要祭出git rebase -i 這個大殺器來幫我們修改那些不堪回首的往事。 實際上,git rebase -i並不是一個專門用來修改歷史記錄的命令,而是一個讓我們可以交互式(就是一個個來) 進行衍合操作的命令,不過我們可以用這個命令來實現對於提交歷史的修改。 該指令的使用方法是git rebase -i ,例如可以用git rebase -i HEAD~3來修改本次提交、上次提交、上上次提交共三次提交。 如圖,我如果向修改這三次提交,輸入git rebase -i HEAD~3,就會出現如下的介面: 這是一個vim 編輯器的介面,這裡是讓我們編輯這一段腳本,可以使用的指令有下方註解中的六個指令。當退出目前編輯其的頁面後,git 就會根據這個腳本一個個的針對提交執行對應的操作(從最早的那次提交開始執行)。 如果只是想修改提交信息,就把所有的 pick 改成 r ,然後:wq保存,接下來 git 就會讓你一個個的從最早的提交信息開始修改。 剩餘的指令中, e 是會在修改對應提交時跳出vim 編輯器,此時HEAD 指標指向這次提交,此時可以用git commit --amend對這次提交進行各種修改,然後執行git rebase --continue就會繼續下一次操作;s 則是會在修改對應提交的時候把這次的提交和其父提交合併為一次提交;f 是和s類似但是會忽略當前提交的信息,直接採用父提交的信息;x 是需要在x 之後輸入命令然後在HEAD 指向這次提交的時候執行。利用這些命令還可以完成重排提交、分割提交的動作。終極殺手git filter-branch
假如說我們提交了N 多次以後,突然發現我們這些提交的郵箱都寫錯了(╯°□° )╯︵ ┻━┻,這個時候如果使用之前提到的命令,估計還沒改完就要累死了。這個時候我們就可以使用git filter-branch來重寫分支,其可以批量的對每個提交執行我們預設的動作。git filter-branch指令使用的基本使用格式是git filter-branch -- '指令' ,不同的filter 會提供給命令不同的輸入和輸出。例如,--msg-filter表示修改提交信息,原提交信息從標準輸入讀入,新提交信息輸出到標準輸出;--tree-filter表示修改文件列表等等等。最後會有一個重寫的範圍。例如,git filter-branch --env-filter 'GIT_AUTHOR_EMAIL=john@example.com export GIT_AUTHOR_EMAIL' HEAD 就可以用來重寫郵箱。建議在調用命令之前先出啦一個分支做嘗試再在自己要修改的分支上執行操作。推薦學習:《Git教程》
#
以上是git怎麼修改歷史記錄的詳細內容。更多資訊請關注PHP中文網其他相關文章!