问题:
- 在Windows下用matlab写的代码(.m)文件复制到Linux(Ubuntu)下,注释的中文全是乱码
- 反之,也是一样
原因:
Windows下默认使用的是GB2312编码,Linux默认使用的是UTF-8。 所以在Windows下产生的代码是GB2312编码,在Linux下当然识别为乱码 ; 反之,同理乱码 。
解决方法:
使用linux下的iconv
命令改变文件的编码:
test1.m由GB2312转换成UTF-8(windows下matlab的代码在linux下运行)
iconv -f GB2312 -t UTF-8 test1.m -o test1.m
test2.m由UTF-8转换成GB2312(linux下matlab的代码在windows下运行)
iconv -f UTF-8 -t GB2312 test2.m -o test2.m
如果文件过多,要进行批处理,可用如下编写的shell脚本批量转换编码。(脚本来自linux公社,点击我立刻下载)
使用方法: 将该脚本放在需要进行转换的文件夹中, 执行脚本,可以将当前目录和其子目录下的所有文件转换成指定的编码方法 。
执行如下:
由GB2312转换成UTF-8
./convertMatlab.sh win
由UTF-8转换成GB2312
./convertMatlab.sh linux
提示: 普通用户没有执行权限,需要用chmod +x convertMatlab.sh
增加执行权限
附:Shell脚本(convertMatlab.sh)