GIT入门笔记(12)- 删除文件、提交删除和恢复删除
2017-03-11 17:21
531 查看
在Git中,删除也是一个修改操作,我们实战一下,
1、先添加add一个新文件test.txt到Git并且提交commit到本地版本库:
$ git add test.txt
$ git commit -m "add test.txt"
[master 94cdc44] add test.txt
1 file changed, 1 insertion(+)
create mode 100644 test.txt
2、删除工作区中的文件
一般情况下,你通常直接在文件管理器中把没用的文件删了,或者用rm命令删了:
$ rm test.txt
这个时候,Git知道你删除了文件,因此,工作区和版本库就不一致了,git status命令会立刻告诉你哪些文件被删除了:
$ git status
# On branch master
# Changes not staged for commit:
# (use "git add/rm <file>..." to update what will be committed)
# (use "git checkout -- <file>..." to discard changes in working directory)
#
# deleted: test.txt
#
no changes added to commit (use "git add" and/or "git commit -a")
现在你有两个选择,一是确实要从版本库中删除该文件,那就用命令git rm删掉,并且git commit:
3、删除后处理
3.1、提交删除
$ git rm test.txt
rm 'test.txt'
$ git commit -m "remove test.txt"
[master d17efd8] remove test.txt
1 file changed, 1 deletion(-)
delete mode 100644 test.txt
现在,文件就从版本库中被删除了。
3.2、回退删除
另一种情况是删错了,因为版本库里还有呢,所以可以很轻松地把误删的文件恢复到最新版本:
$ git checkout -- test.txt
git checkout其实是用版本库里的版本替换工作区的版本,无论工作区是修改还是删除,都可以“一键还原”。
4、小结
命令git rm用于删除一个文件。
如果一个文件已经被提交到版本库,那么你永远不用担心误删,
但是要小心,你只能恢复文件到最新版本,你会丢失最近一次提交后你修改的内容。
1、先添加add一个新文件test.txt到Git并且提交commit到本地版本库:
$ git add test.txt
$ git commit -m "add test.txt"
[master 94cdc44] add test.txt
1 file changed, 1 insertion(+)
create mode 100644 test.txt
2、删除工作区中的文件
一般情况下,你通常直接在文件管理器中把没用的文件删了,或者用rm命令删了:
$ rm test.txt
这个时候,Git知道你删除了文件,因此,工作区和版本库就不一致了,git status命令会立刻告诉你哪些文件被删除了:
$ git status
# On branch master
# Changes not staged for commit:
# (use "git add/rm <file>..." to update what will be committed)
# (use "git checkout -- <file>..." to discard changes in working directory)
#
# deleted: test.txt
#
no changes added to commit (use "git add" and/or "git commit -a")
现在你有两个选择,一是确实要从版本库中删除该文件,那就用命令git rm删掉,并且git commit:
3、删除后处理
3.1、提交删除
$ git rm test.txt
rm 'test.txt'
$ git commit -m "remove test.txt"
[master d17efd8] remove test.txt
1 file changed, 1 deletion(-)
delete mode 100644 test.txt
现在,文件就从版本库中被删除了。
3.2、回退删除
另一种情况是删错了,因为版本库里还有呢,所以可以很轻松地把误删的文件恢复到最新版本:
$ git checkout -- test.txt
git checkout其实是用版本库里的版本替换工作区的版本,无论工作区是修改还是删除,都可以“一键还原”。
4、小结
命令git rm用于删除一个文件。
如果一个文件已经被提交到版本库,那么你永远不用担心误删,
但是要小心,你只能恢复文件到最新版本,你会丢失最近一次提交后你修改的内容。
相关文章推荐
- GIT入门笔记(7)- 修改文件并向版本库提交
- 从Git仓库中恢复已删除的分支、文件或丢失的commit[转]
- 从Git仓库中恢复已删除的分支、文件或丢失的commit
- git删除目录下的所有文件并提交
- Eclipse恢复已删除的文件和代码、svn使用了还原,但本地的没有提交找回没提交代码的方法
- git checkout----若删除文件,恢复到线上库最新代码
- Git 仓库中删除大文件的历史提交记录
- 【Git学习笔记】对已经添加到仓库的文件修改后再次提交到仓库
- Git学习笔记一--创建版本库、添加文件、提交文件等
- 【Git学习笔记】删除文件及文件夹,并push到远程库
- 如何永久删除git仓库中敏感文件的提交记录
- 从git仓库中删除误提交的文件
- git 恢复误删除的文件
- git恢复删除文件
- git commit操作 git恢复删除文件操作
- git远端删除被提交后又被加到.gitignore的文件
- 如何恢复 git reset --hard 删除的文件
- git恢复误删文件及省去密码提交
- Git学习笔记三--管理修改、撤销修改、删除文件
- 从Git仓库中恢复已删除的分支、文件或丢失的commit