"

经历不是一句鸡汤。说教不过两片嘴唇的触碰,经历确是风雨里的打磨。不经我苦难,莫劝我向善。


—— 小闫同学

"


诡异之事年年有,只是今年有点多,在仓库上传到 ​​GitHub​​​ 后,偶然在 ​​GitHub​​​ 中瞄了一眼,我的天?这个图标不像文件夹啊?这个怎么点不开?​​git​​ 上传正常啊?本地工作区和暂存区都是干净的了啊?​更多精彩文章请关注公众号『Pythonnote』或者『全栈技术精选』

一、问题描述

本地仓库提交后,​​GitHub​​ 中某文件夹无法正常点击,内容无法显示。

二、原因分析

经排查,定位到原因:之前仓库中包含了一个特殊的文件夹(此文件夹是另外一个 ​​git​​ 仓库),在执行下面语句时:

git add .

提示仓库中包含其他仓库,需要解决此问题。本人操作是删除掉此文件夹中的 ​​.git​​ 配置目录,然后依次执行以下命令:

git add .
git commit -m 'add the new file'
git push

顺利推送仓库到远程,过程中并无报错。这个过程或许是导致问题的原因。更多精彩文章请关注公众号『Pythonnote』或者『全栈技术精选』

三、解决办法

现在问题是本地工作区与暂存区干净如新,远程仓库有问题。该如何解决?这时用到了一个命令:

git rm --cached <dir_name>

我们先来看一下手册:

usage: git rm [<options>] [--] <file>...


-n, --dry-run dry run
-q, --quiet do not list removed files
--cached only remove from the index
-f, --force override the up-to-date check
-r allow recursive removal
--ignore-unmatch exit with a zero status even if nothing matched

可以看到 ​​--cached​​ 的作用:将文件仅仅从索引中移除,翻译成人能看懂的话便是 「之前已经提交,现在将此目录释放掉,恢复到工作区,未被追踪的状态,即 ​​git add .​​ 命令之前的状态」

我们执行完此命令之后使用如下命令查看所有改变后的文件状态:

git status

发现出问题的目录已经变成了红色未被追踪的状态,此时将出问题的目录中所有包含 ​​git​​ 信息的文件和目录都删除,然后再依次执行命令:

git add .
git commit -m 'add the new file'
git push

去远程仓库中查看后发现问题解决。更多精彩文章请关注公众号『Pythonnote』或者『全栈技术精选』

四、总结

当出现未知问题致使远程仓库同预期结果不一致时,本地可以将问题目录恢复到未被追踪状态,核查完问题之后再次提交最新结果,操作步骤如下:

1.删除缓存,释放目录,恢复到未被追踪状态:

git rm --cached <dir_name>

2.依次执行如下操作再次提交:

git add .
git commit -m 'Information you need to submit'
git push

3.完美解决问题。更多精彩文章请关注公众号『Pythonnote』或者『全栈技术精选』


git rm --cached 命令如何解决疑难杂症_python