【实践】清空 GitHub 仓库中的所有内容,只保留 README.md
文件
🌈你好呀!我是 是Yu欸 🌌 2024每日百字篆刻时光,感谢你的陪伴与支持 ~🚀 欢迎一起踏上探险之旅,挖掘无限可能,共同成长!
前些天发现了一个人工智能学习网站,内容深入浅出、易于理解。如果对人工智能感兴趣,不妨点击查看。
写在最前面
在删除github静态网页的CNAME指向后,
这个网址yutong-a.github.io,还是会自动跳转到已过期域名https://lightrain.top/上,因此进行原因查找。
在仓库中搜索时,发现之前自带的资源导致了这一原因,因此尝试清空一个 GitHub 仓库中的所有内容,但想要保留
README.md
文件和
.git
目录(
.git
目录实际上不会被推送到 GitHub,但它包含了仓库的版本历史和配置信息)。
最终结果
清空github仓库
可以按照以下步骤操作:
注意事项
- 这个过程会清除你仓库中的大部分内容,只留下
README.md
文件。请确保你已经备份了所有重要数据。 .git
目录是 Git 用来跟踪和管理版本历史的目录,它位于仓库的顶级目录下。这个目录在正常的 Git 操作中是不会被删除的,也不会被推送到远端仓库(GitHub),所以你的版本历史会被保留。- 如果你在 GitHub 上直接进行操作,而不是在本地仓库,你需要手动删除每个文件(除了
README.md
),因为 GitHub 不允许通过网页界面直接删除所有文件。
这些步骤允许你清理仓库内容,同时保留 README 文件和版本历史,适合于想要重新开始但保留一些基本信息的场景。
一、初始化本地仓库
如果没有初始化本地仓库,会报错:
git init
二、设置远程仓库
遇到这个问题通常是因为 Git 无法识别远程仓库
origin
,或者你没有正确设置远程仓库的 URL。这可能是由于以下几个原因造成的:
1. 远程仓库 URL 没有设置或设置错误
可以通过以下命令查看远程仓库的设置:
git remote -v
这将列出所有远程仓库的 URL。如果
origin
没有列出,或者 URL 不正确,你需要添加或修改它。
添加远程仓库
如果
origin
不存在,你需要使用
git remote add
命令来添加远程仓库:
git remote add origin https://github.com/用户名/仓库名.git
将
用户名
和
仓库名
替换为你的 GitHub 用户名和仓库名。
修改远程仓库
如果
origin
的 URL 不正确,你可以用
git remote set-url
来修改它:
git remote set-url origin https://github.com/用户名/仓库名.git
同样,记得替换
用户名
和
仓库名
。
2. 访问权限问题
如果远程仓库的 URL 是正确的,但你仍然看到“Could not read from remote repository”的错误,可能是因为你没有正确设置访问权限。
- 确保你的 GitHub 用户名和密码是正确的。如果你启用了两因素认证(2FA),你可能需要使用个人访问令牌(PAT)作为密码。
- 确保你使用的是 HTTPS 或 SSH URL,且 URL 是正确的。SSH URL 需要你在 GitHub 上配置 SSH 密钥。
3. 仓库不存在
如果你的 URL 是正确的,且你有正确的访问权限,那么请确保 GitHub 上的仓库确实存在。如果仓库被删除或重命名,你需要更新你的远程仓库 URL 来反映这些变化。
检查和解决步骤
- 检查远程仓库 URL:使用
git remote -v
查看并确认origin
的 URL 是正确的。 - 添加或修改远程仓库:根据需要添加或修改
origin
。 - 检查访问权限:确保你有权限访问该仓库,特别是如果仓库是私有的。
- 确认仓库存在:在 GitHub 上确认仓库确实存在。
完成这些步骤后,尝试再次推送你的更改。
三、克隆仓库到本地(如果尚未克隆)
首先,确保你有该仓库的一个本地副本。如果没有,需要先克隆仓库:
git clone https://github.com/用户名/仓库名.git
cd 仓库名
四、删除除了
README.md
外的所有文件
在仓库的根目录中,删除所有文件和目录,除了
README.md
。这可以通过以下命令完成:
# 在仓库根目录执行# 注意: 这将删除除了 README.md 外的所有文件和目录,请确保已备份必要内容find.-not-name'README.md'-not-name'.git'-not-name'.'-not-name'..'-delete
如果你的
README.md
文件位于仓库的子目录中,你可能需要调整上面的命令,或者手动删除其他文件和目录。
当你尝试使用
find
命令来删除除
README.md
和
.git
外的所有文件和目录时,你可能会遇到“Directory not empty”的错误。这是因为
find
命令在尝试删除非空目录时会遇到问题。为了解决这个问题,你可以采取一种分步的方法来先删除目录内的所有文件(保留
README.md
),然后再删除空目录。
下面是一种改进的方法,它会先删除所有非目录文件(除了
README.md
),然后删除空的目录:
1. 删除所有非目录文件(除了
README.md
)
你可以使用
find
命令匹配所有非目录文件,并排除
README.md
,然后删除它们:
find.-type f -not-name'README.md'-delete
2. 删除所有空目录
然后,你可以使用另一个
find
命令来删除所有空的目录。请注意,由于某些目录可能只在删除其子目录后变为空,你可能需要运行命令多次:
find.-type d -empty-delete
你可能需要运行上面的删除空目录命令几次,直到所有空目录都被删除。
提交更改前看一下本地仓库,确认是否是所需要的。
五、提交更改并推送
接下来,将这些更改提交到本地仓库,并推送到 GitHub:
gitadd *
git commit -m"清空仓库,保留 README.md"git push origin main
如果你的默认分支不是
master
,请将上述命令中的
master
替换为你的默认分支名(如
main
)。
六、强制更新
![rejected] main -> main (fetch first)
error: failed to push some refs to 'https://github.com/YuTong-a/YuTong-a.github.io'
hint: Updates were rejected because the remote contains work that you do not
hint: have locally. This is usually caused by another repository pushing to
hint: the same ref. If you want to integrate the remote changes, use
hint: 'git pull' before pushing again.
hint: See the 'Note about fast-forwards'in'git push --help'for details.
遇到这个问题是因为你的本地仓库落后于远程仓库,远程仓库包含了一些你本地没有的提交。Git 默认要求在推送之前本地仓库需要是最新的,这是为了防止潜在的冲突。这里有几种解决方法:
方法 1: 拉取远程仓库的更改并合并
如果你想保留远程仓库的更改,并将它们合并到你的本地更改中,可以使用以下命令:
git pull origin main
这会拉取远程仓库的更改并自动尝试合并到你的本地分支。如果存在合并冲突,Git 会提示你解决它们。解决冲突后,你可以继续提交并推送。
方法 2: 强制推送(慎用)
如果你确定想要覆盖远程仓库的更改(例如,你的目标是重置远程仓库以匹配你的本地仓库),你可以使用强制推送。请注意,这将会丢失远程仓库中的所有更改,只有在你完全确定这是你想要的操作时才使用。
git push origin main --force
或者使用更新的语法:
git push origin main --force-with-lease
--force-with-lease
选项比
--force
更安全一些,因为它会在远程分支没有被更新时阻止你进行强制推送。这是一个防止不小心覆盖他人更改的安全措施。
选择适合你情况的方法
- 如果你想保留远程仓库中的更改并将它们合并到你的工作中,选择方法 1。
- 如果你需要清空远程仓库以匹配你的本地版本,并且你确定这样做不会意外丢失重要的更改,选择方法 2。
在进行强制推送之前,确保与团队中的其他成员沟通,确认这个操作不会影响他们的工作。
版权归原作者 是Yu欸 所有, 如有侵权,请联系我们删除。