git stash drop 误用恢复

场景

代码正在开发中不想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即可

  • 21
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 8
    评论
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值