赞
踩
1.撤销某条提交记录
git revert <提交记录>
例:
#所有 abcd 提交的修改将被撤销,git 实际上将创建一条新的提交,旧的提交不会被真的改变
#如果有冲突,需要手动解决冲突
git revert abcd
2. 撤销git add操作
如果将某个文件/目录更新到了 index 中,在执行 git commit 之前,如果希望将文件/目录从 index 中移除,则可以
执行以下操作:
git reset HEAD <路径>
例:git reset HEAD file.txt
注意:如果代码已经通过 git commit 提交,则不能执行此操作。
[“HEAD 等价于当前分支的末端。]
git reset 确实是个危险的命令,如果加上了 --hard 选项则更是如此。 然而在上述场景中,工作目录中的文件尚未修改,因此相对安全一些。
3. 撤销本地操作
如果在本地修改了某个文件之后,希望撤销自己的修改(将文件恢复为最近一次提交的状态),则可以使用以下
操作:
git checkout -- <路径>
例:git checkout -- file.txt
注意:
如果代码已经通过 git commit 提交,则不能执行此操作。
请务必记得 git checkout -- <file> 是一个危险的命令。 你对那个文件在本地的任何修改都会消失——Git 会用最近提交的版本覆盖掉它。 除非你确实清楚不想要对那个文件的本地修改了,否则请不要使用这个命令。
4、撤消修改(git commit --amend)
有时候我们提交完了才发现漏掉了几个文件没有添加,或者提交信息写错了。 此时,可以运行带有 --amend 选项的提交命令来重新提交:
这个命令会将暂存区中的文件提交。 如果自上次提交以来你还未做任何修改(例如,在上次提交后马上执行了此命令), 那么快照会保持不变,而你所修改的只是提交信息。
文本编辑器启动后,可以看到之前的提交信息。 编辑后保存会覆盖原来的提交信息。
【例如,你提交后发现忘记了暂存某些需要的修改,可以像下面这样操作:
$ git commit -m 'initial commit'
$ git add forgotten_file
$ git commit –amend
最终你只会有一个提交——第二次提交将代替第一次提交的结果。】
【当你在修补最后的提交时,并不是通过用改进后的提交 原位替换 掉旧有提交的方式来修复的, 理解这一点非常重要。从效果上来说,就像是旧有的提交从未存在过一样,它并不会出现在仓库的历史中。
修补提交最明显的价值是可以稍微改进你最后的提交,而不会让“啊,忘了添加一个文件”或者 “小修补,修正笔误”这种提交信息弄乱你的仓库历史。】
1. 删除本地分支
git branch -d <分支名称>
2.强制删除本地分支
git branch -D <分支名称>
3.删除文件/目录
rm test.txt #执行完,工作区的相应文档删除,相当于直接在电脑中手动删除此文档
这个时候,Git知道你删除了文件,因此,工作区和版本库就不一致了,git status命令会立刻告诉你哪些文件被删除了:此时,删除文件在工作区没有了,但是在版本库还存在。
现在你有两个选择,一是确实要从版本库中删除该文件,那就用命令git rm删掉,并且git commit:
$ git rm test.txt
$ git commit -m "remove test.txt"
另一种情况是删错了,因为版本库里还有呢,所以可以很轻松地把误删的文件恢复到最新版本:
$ git checkout -- test.txt
git checkout其实是用版本库里的版本替换工作区的版本,无论工作区是修改还是删除,都可以“一键还原”。
注意:从来没有被添加到版本库就被删除的文件,是无法恢复的!
4. 删除本地标签
git tag -d <标签名>
git rm命令用于从工作区和索引中删除文件。
Vim d1.txt
git add d1.txt
git commit –m ‘上传到本地库d1.txt’ d1.txt
2.执行命令进行删除:
git rm d1.txt à工作区删除后,提交到本地库git commit –m ‘删除d1.txt’ d1.txt
3.通过日志git reflog 找回
$ git reset --hard 15d5002
4.ll查看即可。
注意:git只要在本地库发生操作,都会进行版本记录。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。