场景
代码正在开发中不想commit,但是要切换其它分支去处理临时紧急任务,于是git stash 备份当前的工作区的内容。
切换回来时不小心使用了:git stash drop ,于是暂存的修改全部没有了。
方法一 知道删除的ID号
知道删除的ID号如
然后通过命令git fsck –lost-found找到最近的一些删除的提交,找到f3106e*,然后git show f3106e*查看修改情况,git stash apply f3106e*即可修复删除掉的内容了。
方法二 不知道删除的ID号但是大概记得自己修改了哪些内容
step1 内容存入文件
git fsck --lost-found >> 1.txt
或
git fsck --unreachable >> 2.txt
然后两个文件的内容格式如下
step2 筛选指定信息并记住ID,创建脚本快速查找
#!/bin/sh
READFILENAME="1.txt" #上步文件名【1.txt dangling commit,2.txt对应unreachable commit】
RETFILENAME="./ret.txt" #筛选结果文件名
while read -r line
do
VAR=`echo $line | awk '/dangling commit/ {print $3}'`
if [ $VAR ]; then
git show $VAR >> $RETFILENAME
echo "-------------------------------------\n" >>$RETFILENAME #每条记录用---分割开
fi
done < $READFILENAME
step3 根据结果找回删除的代码
如我删除的是commit 8a6229188074d5ce270ac4405179323d7c01b78e
然后 git stash apply 8a6229188074d5ce270ac4405179323d7c01b78e即可