Git 踩坑记录

1 文件/目录大小写问题(Windows/macOS)

Git 默认对大小写不敏感,修改文件夹大小写可能无法在远程仓库更新。

方法 1:临时改名

bash 复制代码
git mv FolderName tempname
git commit -m "临时改名"
git push

git mv tempname foldername
git commit -m "改回目标大小写"
git push

方法 2:强制更新

bash 复制代码
git config core.ignorecase false
git add -A
git commit -m "修正大小写"
git push

清除缓存(必要时)

bash 复制代码
git rm -r --cached FolderName
git add foldername
git commit -m "修正大小写"
git push

2 中文路径异常

注意:不考虑 SVN 分支

Git 输出中文路径可能乱码,解决方法:

bash 复制代码
git config --global core.quotepath false

作用:禁用输出路径的引号和转义,使 git status/git log 更易读。

3 SVN 仓库迁移到 Git

bash 复制代码
# 初始化 git-svn 仓库
git svn init https://example.com/svn/repo

# 拉取指定版本及作者对应
git svn fetch -A authors.txt -r 0:100 

# 合并 svn 分支到 master
git merge remotes/git-svn

# 回退至指定版本(可选)
git svn reset -r 4000
txt 复制代码
# authors.txt 示例
yaoxin = BeyondXinXin <779354187@qq.com>
VisualSVN Server = BeyondXinXin <779354187@nt.com>

注意:需要完整作者映射表

4 批量替换作者

重写历史时统一作者信息,适合迁移或整理历史仓库。

注意:执行前一定要备份仓库,否则历史被重写无法恢复。

bash 复制代码
# 1. 安装工具
python install git-filter-repo

# 2. 将可执行程序放到 Git 执行目录(Windows 示例)
# C:\Users\HP\AppData\Roaming\Python\Python312\Scripts\git-filter-repo.exe
# C:\Program Files\Git\bin\git-filter-repo.exe

# 3. 创建映射文件 mailmap.txt
# 内容示例:
# BeyondXin <779354187@qq.com>

# 4. 执行替换(提前备份仓库,如果不用 --force 需要先 clone 新仓库)
git filter-repo --mailmap ../mailmap.txt --force

# 5. 清除引用标记
:: delete_replaces.bat
@echo off
for /f "delims=" %%i in ('git replace -l') do (
    git replace -d %%i
)
相关推荐
超梦dasgg13 分钟前
工作中 Git 完整使用指南(职场实战版)
git
Ws_17 分钟前
Git + Gerrit 第七课:stash 临时保存工作区修改
git
enjoywindstorm1 小时前
git从入门到精通
git
Adorable老犀牛5 小时前
Git 发布正式版本的一个专属的硬核功能,叫做 打标签(Tag)。
git
我先去打把游戏先7 小时前
Ubuntu虚拟机(服务器版本)Git卸载完全教程——彻底移除与清理配置
服务器·git·单片机·嵌入式硬件·物联网·ubuntu·51单片机
不做无法实现的梦~8 小时前
Git Clone 使用 Watt/Steam++ 加速时报证书错误的原因与解决方法
大数据·git·elasticsearch
黑猫警长丶9 小时前
Git 操作笔记
笔记·git
MageGojo9 小时前
Whois 域名查询 API 接入实战:用一个 GET 请求获取域名注册信息
java·git·github
黑猫警长丶9 小时前
Git 本地操作基础
git
白狐_79810 小时前
从功能开发到开源维护:一个 Python 可视化项目的 Git 分支、维护文件与 PR 流程实践
git·python·开源