一、简述
IDEA中设置了文件全局编码为UTF8之后,对于原先GB2312编码的项目出现乱码。于是想将GB2312编码的文件全部转码成UTF8的。首先尝试使用notepad,该编辑器一次只能转码一个文件,效率不高,解决方法有安装python脚本插件,看起来有点麻烦。于是想到windows上可以使用git bash,而bash中转码命令iconv。下面使用这个命令来完成批量原地转码。
二、尝试
1. 看到别人博客https://www.cnblogs.com/makefile/p/4002434.html,这个博客中使用的命令如下
find . -name "*.java" -exec sh -c "iconv -f GB18030 -t UTF8 {} -o {}" \;
测试了一下,这个在linux上是可行的。但是在windows上报错如下
iconv: -o: No such file or directory
sh命令中的{}表示当前匹配的文件,很明显-o的输出文件找不到。说明在windows上iconv并不支持-o参数(猜想)
2. 新的方式
iconv命令,除了使用-o参数输出文件外,还可以使用输出重定向符>。需要注意两点,其一如果输入文件和输出文件一样,那么输入文件和输出文件都将会被清空;其二输出文件的上层目录必须存在。该方式在linux上和windows上均有效。
三、解决
在确定使用输出重定向后,按照两点注意事项,最终的命令如下
find . -name "*.java" -exec bash -c 'mkdir -p temp/$(dirname {}); iconv -f gb2312 -t utf-8 {} > temp/{} && mv temp/{} {}' \; && rm -rf temp
注: 该命令会在当前目录下临时创建temp目录 因此temp目录需要是之前不存在的,如果已经存在,则修改命令中temp为其他名称