在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'
结果
能正常显示中文了