java中更新文件时,指定原文件的编码格式,防止编码格式不对,造成乱码
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);
作者:guanbin —— 纵码万里千山
出处:https://www.cnblogs.com/guanbin-529/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。