在windows中使用git的时候,我的文件main.c是GB2312编码的。

在使用 git add后,使用git diff --cached查看时,出现了中文乱码的问题

解决方法
- 在
git仓库的根目录下,新建一个文件.gitattributes,文件内容为
// 将后缀为.c的文件在diff的时候使用cp936_2_utf8编码转换方式进行
// cp936_2_utf8是随便命名的
// cp936是windows的编码格式GBK(兼容GB2312),utf8是我们需要的编码格式
// 因为在vscode的terminal中是以utf8格式显示的
*.c text diff=cp936_2_utf8
// 添加所有的文件需要转换的方式
- 在
.git/config或根目录下新建文件.gitconfig(.gitconfig理论上可行,但是没成功),文件中添加代码,内容为
[diff "cp936_2_utf8"]
textconv = iconv -f cp936 -t utf-8
或者可以使用代码进行配置,如下所示
git config [--global|--local] diff.cp936_2_utf8.textconv 'iconv -f cp936 -t utf-8'
结果

能正常显示中文了
文章讲述了如何在Windows中使用Git处理GB2312编码的文件时避免中文乱码,方法是在.gitattributes中设置文件编码转换,或在.gitconfig中配置textconv。通过iconv工具将GBK转换为UTF-8,确保在VSCode终端显示正常。
7487

被折叠的 条评论
为什么被折叠?



