如何从Git存储库中删除包含文件的单个目录?
当前回答
你可以试试这个:git rm-rf<目录名>
它将强制删除目录。
其他回答
我之前已经提交了该文件夹,并希望删除历史记录中的目录。
我执行了以下操作:
将文件夹添加到.gitignore:
echo Folder_Name/ >> .gitignore
从所有提交中删除:
git filter-branch --index-filter 'git rm -rf --cached --ignore-unmatch Folder_Name/' --prune-empty --tag-name-filter cat -- --all
从旧提交中删除refs:
git for-each-ref --format="%(refname)" refs/original/ | xargs -n 1 git update-ref -d
确保完全删除所有旧引用
rm -Rf .git/logs .git/refs/original
执行垃圾收集
git gc --prune=all --aggressive
将更改推送到在线存储库:
git push
你到此为止。
但您可以通过以下操作将所有更改推送到所有分支:但是要小心这个命令!
git push origin --all --force
git push origin --tags --force
之后,该文件夹从git中删除,但没有从本地磁盘中删除。
从Git和本地删除目录
使用两个目录签出“master”:
git rm -r one-of-the-directories // This deletes from filesystem
git commit . -m "Remove duplicated directory"
git push origin <your-git-branch> (typically 'master', but not always)
从Git中删除目录,但不是本地目录
要从Git中删除此目录,但不将其从文件系统(本地)中完全删除,请执行以下操作:
git rm -r --cached myFolder
您可以使用Attlasian源树(Windows)(https://www.atlassian.com/software/sourcetree/overview). 只需从树中选择文件并按下顶部的“删除”按钮。文件将从本地存储库和本地git数据库中删除。然后提交,然后推送。
转到git目录,然后键入以下命令:rm-rf<目录名>
删除目录后,通过以下方式提交更改:gitcommit-m“您的提交消息”
然后只需在远程GIT目录上推送更改:git推送原点<分支名称>
要添加新目录:
mkdir <YOUR-DIRECTORY>
但是现在Git不知道这个新目录,因为Git跟踪的是文件而不是目录目录
git status
Git不会意识到我们所做的更改,所以我们添加了hidden.keep文件,以使Git意识到新的更改。
touch /YOUR-directory/.keep
现在,如果你点击git状态,git就会知道这些变化。
如果要删除目录,则应使用此命令。
rm -r <YOUR-DIRECTORY>
如果您使用gitstatus进行检查,您将看到目录已被删除。
推荐文章
- 在单个文件中重新启动/撤消冲突解决方案
- Visual Studio代码如何解决合并冲突与git?
- 无法推送到远程分支,无法解析到分支
- Git:如何将数据库重置为特定的提交?
- 如何在合并期间使用Git和命令行保存本地文件或远程文件?
- 能够用一个命令推到所有git遥控器?
- 重新基于Git合并提交
- 忽略已经签入目录的内容?
- 如何从windows cmd保存git提交消息?
- (Mac) -bash: __git_ps1:命令未找到
- 如何删除多个已删除的文件在Git仓库
- 使用vimdiff查看所有' git diff '
- 如何拉特定的目录与git
- 本地存储库中的文件与源文件之间的差异
- 将Git存储库内容移动到另一个存储库,保存历史记录