1.pom中添加引入cpdetector(一个可以自动检测文本编码格式的项目)
//pom中添加引入cpdetector(一个可以自动检测文本编码格式的项目)
<dependency>
<groupId>net.sourceforge.cpdetector</groupId>
<artifactId>cpdetector</artifactId>
<version>1.0.7</version>
</dependency>
2.获取文件的编码格式 charset
public static Charset detectCodepage(String filePath) throws IOException {
CodepageDetectorProxy detector = CodepageDetectorProxy.getInstance();
detector.add(UnicodeDetector.getInstance());
detector.add(ASCIIDetector.getInstance());
detector.add(JChardetFacade.getInstance());
File file = new File(filePath);
Charset charset = detector.detectCodepage(file.toURL());
logger.info("the {} charset is {}",filePath,charset.displayName());
}
3.指定更新文件的编码格式
//FileOutputStream中一个参数是文件路径,一个是指是否在文件尾进行追加
BufferedWriter bufferedWriter = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(filePath,true), charset);