这是我第一次使用git,我想将现有项目导入github,一切都被删除了。在搜索完答案之后,我认为git在git pull之后删除了文件,我正在尝试恢复文件和文件夹,但我找不到如何做到这一点。
我完成了下一步:
jesus@jesus-K52F:~/Escritorio/Django/Ujixy$ git init
Initialized empty Git repository in /home/jesus/Escritorio/Django/Ujixy/.git/
jesus@jesus-K52F:~/Escritorio/Django/Ujixy$ git add .
jesus@jesus-K52F:~/Escritorio/Django/Ujixy$ git status
# On branch master
#
# Initial commit
#
# Changes to be committed:
# (use "git rm --cached <file>..." to unstage)
#
# new file: Catalogoapp/__init__.py
# new file: Catalogoapp/models.py
# new file: Catalogoapp/tests.py
# new file: Catalogoapp/views.py
# new file: Messageapp/__init__.py
# new file: Messageapp/models.py
# new file: Messageapp/tests.py
# new file: Messageapp/views.py
# new file: Ujixyapp/__init__.py
[...]
jesus@jesus-K52F:~/Escritorio/Django/Ujixy$ git push origin master
fatal: 'origin' does not appear to be a git repository
fatal: The remote end hung up unexpectedly
jesus@jesus-K52F:~/Escritorio/Django/Ujixy$ git add *
jesus@jesus-K52F:~/Escritorio/Django/Ujixy$ git status
# On branch master
#
# Initial commit
#
# Changes to be committed:
# (use "git rm --cached <file>..." to unstage)
#
# new file: Catalogoapp/__init__.py
# new file: Catalogoapp/models.py
# new file: Catalogoapp/tests.py
# new file: Catalogoapp/views.py
# new file: Messageapp/__init__.py
# new file: Messageapp/models.py
# new file: Messageapp/tests.py
# new file: Messageapp/views.py
# new file: Ujixyapp/__init__.py
[...]
jesus@jesus-K52F:~/Escritorio/Django/Ujixy$ git remote add origin https://github.com/PEREYO/Ujixy.git
jesus@jesus-K52F:~/Escritorio/Django/Ujixy$ git pull origin master
remote: Counting objects: 3, done.
remote: Total 3 (delta 0), reused 0 (delta 0)
Unpacking objects: 100% (3/3), done.
From https://github.com/PEREYO/Ujixy
* branch master -> FETCH_HEAD
jesus@jesus-K52F:~/Escritorio/Django/Ujixy$ git push origin master
Username for 'https://github.com': PEREYO
Password for 'https://PEREYO@github.com':
Everything up-to-date
jesus@jesus-K52F:~/Escritorio/Django/Ujixy$ git init
Reinitialized existing Git repository in /home/jesus/Escritorio/Django/Ujixy/.git/
jesus@jesus-K52F:~/Escritorio/Django/Ujixy$ git add *
jesus@jesus-K52F:~/Escritorio/Django/Ujixy$ git status
# On branch master
nothing to commit (working directory clean)
现在我正在尝试修复下一步:
jesus@jesus-K52F:~/Escritorio/Ujixy$ git fsck --lost-found
Checking object directories: 100% (256/256), done.
dangling tree bfe11a30d57a0233d3b0c840a3b66f6421987304
jesus@jesus-K52F:~/Escritorio/Ujixy$ git status
# On branch master
nothing to commit (working directory clean)
jesus@jesus-K52F:~/Escritorio/Ujixy$ git reflog
61daa69 HEAD@{0}: initial pull
jesus@jesus-K52F:~/Escritorio/Ujixy$ git cat-file -p bfe11a30d57a0233d3b0c840a3b66f6421987304
040000 tree 9196501a346cfe4347f46d82936745b78b0235b9 Catalogoapp
040000 tree 49561b4bd6adb8fe8bb1915d6bef09cd49195a97 Messageapp
040000 tree 0fb58bf9b56397443fb235e2a38045d6df7cd473 Ujixyapp
100644 blob e69de29bb2d1d6434b8b29ae775ad8c2e48c5391 __init__.py
100644 blob dfe3388ddf2d5ba34559eb3ec56199d83cdce8bd __init__.pyc
100644 blob bcdd55e27be9447bf6b224b8ba0cbc6802509862 manage.py
100644 blob 34c5978d8026844038d530b491828398bc3ea6c7 settings.py
100644 blob 167a6b1965426ec30c25535fe27338b61b2ae0cf settings.pyc
100644 blob 4a7215cb90ae95d64ca30fde1c1277e0155eb4ed urls.py
100644 blob 6eedcddafbc8854f70f44181edac8e63781cfb09 urls.pyc
但是,如何恢复包含所有文件和文件夹的目录?现在我正在使用.git文件夹的副本以避免其他问题。
答案 0 :(得分:10)
由于您已经有一个悬垂的树对象的引用,所以你就可以了。以下应该有效:首先将悬空树恢复到Git的索引中:
git read-tree bfe11a30d57a0233d3b0c840a3b66f6421987304
接下来,从现在恢复的索引更新您的工作目录:
git checkout-index -a
答案 1 :(得分:2)
由于您可以在悬空树对象上运行git cat-file -p
,因此您应该能够恢复它。有很多方法,我将描述2我可以很快想到:
创建一个新的提交以引入悬空树中的文件。此提交将没有父级。
echo "A commit to recover the dangling tree." | git commit-tree bfe11a30d57a0233d3b0c840a3b66f6421987304
# Output:
<SOME_NEWLY_CREATED_COMMIT_SHA1>
新提交应该包含您刚刚发现的悬空树的工作树。上述命令的输出应显示已创建的新提交SHA1。
要将当前工作树切换到此提交:
git checkout <SOME_NEWLY_CREATED_COMMIT_SHA1>
现在您应该能够看到悬挂树提交中列出的所有文件和内容。你可以浏览,备份文件,做任何你想做的事情;)
替代方法:
如果您希望在当前提交之上获取更改,则此方法可能很有用。
将树的内容读入git的索引(即进入此案例的暂存区域)。
git read-tree bfe11a30d57a0233d3b0c840a3b66f6421987304
现在在当前签出的分支的顶部提交暂存区域中的更改:
git commit -m "Recover the lost files."
未来:
始终提交您的更改,即使提交在将来悬挂,也更容易找到它们(使用reflog)。如果对git commit
有疑问,可以随时修改提交,进行更改,重写历史记录等。特别是在运行git pull
或git push
之类的命令之前,您应该提交改变,以免他们迷路。
不要在存储库上运行git init
两次,尽管git
足够聪明,知道存储库已经初始化并且尝试不覆盖您的更改。
答案 2 :(得分:-2)
如果您尚未提交这些文件和文件夹,我认为您无法恢复这些文件和文件夹。 Git可以恢复您已经提交到仓库中的任何东西,但是如果您没有首先提交,那么它根本不在回购中。这部分是我喜欢在Dropbox文件夹中使用git的原因。