
Java读取文本文件(比方csv文件、txt文件等),碰到中文就变成乱码。(引荐:java视频教程)
读取代码以下:
List<String> lines=new ArrayList<String>(); BufferedReader br = new BufferedReader(new FileReader(fileName)); String line = null; while ((line = br.readLine()) != null) { lines.add(line); } br.close();
道理:
Java的I/O类处置惩罚如图:
Reader 类是 Java 的 I/O 中读字符的父类,而 InputStream 类是读字节的父类,InputStreamReader 类就是关联字节到字符的桥梁,它担任在 I/O 过程当中处置惩罚读取字节到字符的转换,而细致字节到字符的解码完成它由 StreamDecoder 去完成,在 StreamDecoder 解码过程当中必须由用户指定 Charset 编码花样。值得注意的是假如你没有指定 Charset,将运用当地环境中的默许字符集,比方在中文环境中将运用 GBK 编码。
总结:Java读取数据流的时刻,一定要指定数据流的编码体式格局,不然将运用当地环境中的默许字符集。
经由上述剖析,修正以后的代码以下:
List<String> lines=new ArrayList<String>(); BufferedReader br=new BufferedReader(new InputStreamReader(new FileInputStream(fileName),"UTF-8")); String line = null; while ((line = br.readLine()) != null) { lines.add(line); } br.close();
更多java学问请关注java基础教程栏目。
以上就是java读取文件中文乱码解决方法引见的细致内容,更多请关注ki4网别的相干文章!