查看暂存区文件
git ls-files 命令是用来查看暂存区中文件信息.
参数说明:
- –cached(-c)显示暂存区中的文件,git ls-files命令默认的参数
- –deleted(-d)显示删除的文件
- –modified(-m) 显示修改过的文件
- –other(-o)显示没有被git跟踪的文件
- –stage(-s) 显示mode以及文件对应的Blob对象,进而我们可以获取暂存区中对应文件里面的内容。
实例:
1.查看暂存区中有哪些文件?
git ls-files
2.查看暂存区中test.txt文件内容是什么?
首先,我们需要查查test.txt文件对应的Blob对象,如下:
git ls-files -s – test.txt 或者直接 git ls-files -s
然后通过Blob对象,查询test.txt里面的内容:
git cat-file -p 43ac
还原暂存区的文件
- 当自己在工作区修改或删除某一指定文件,但该文件有一个版本已经上传至暂存区时,可以通过git restore [fileName]将暂存区文件的复制加入到当前工作区。如果该文件被删除,则该文件会被复原;如果该文件被修改,那么文件就会回到修改前的状态。
删除情况
- 新建一个new.txt。
- 通过git add new.txt上传至暂存区。
- 通过rm new.txt删除该文件。
- 通过git ls-files查看到该文件在暂存区有保留。
- 通过git restore new.txt使暂存区保留的new.txt复制一份到工作区
修改情况
- 新建一个new.txt,写入“版本一”字符串。
- 上传至暂存区。
- 修改new.txt的内容为“版本二”
- 执行git restore new.txt,查看工作区的new.txt文件的内容是“版本一”
删除暂存区的文件
- git rm -r --cached [fileName]
- git reset HEAD [fileName]:指定文件回退到最近一次执行push后的的状态,清空暂存区,同时回退工作区文件状态。
- 此时若文件曾被提交至本地库,由于快照与工作区文件不匹配进而提示’deleted : new.txt’,将工作区文件重新提交至本地库即可。如果文件仅仅提交至暂存区而没有提交至本地库,文件在被删除或修改后不会有提示。