欢迎来到三一文库! | 帮助中心 三一文库31doc.com 一个上传文档投稿赚钱的网站
三一文库
全部分类
  • 研究报告>
  • 工作总结>
  • 合同范本>
  • 心得体会>
  • 工作报告>
  • 党团相关>
  • 幼儿/小学教育>
  • 高等教育>
  • 经济/贸易/财会>
  • 建筑/环境>
  • 金融/证券>
  • 医学/心理学>
  • ImageVerifierCode 换一换
    首页 三一文库 > 资源分类 > DOC文档下载
     

    Java读取TXT文本文件乱码解决方案.doc

    • 资源ID:9821572       资源大小:26KB        全文页数:4页
    • 资源格式: DOC        下载积分:2
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录 QQ登录   微博登录  
    二维码
    微信扫一扫登录
    下载资源需要2
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    Java读取TXT文本文件乱码解决方案.doc

    Java读取TXT文本文件乱码解决方案今天在解析一个文本文件的时候出现了乱码,以前从未遇到,花了点时间解决了,在此总结一下:首先,先看一下解析的代码:private String getProjectData()String data = null;try BufferedReader br = new BufferedReader(new (file);String str = br.readLine();data = str.split("t");br.close(); catch ( e) e.printStackTrace(); catch (IOException e) e.printStackTrace();return data;这个方法很简单,就是获取txt文件中的一行数据,然后转换为数组,我这个文本中只有一行。就这种情况下获取到的str是乱码,我想出现乱码肯定是字符集编码的问题,然后自己新建了一个文本文档测试没有问题(开始用的文本时别的程序导出的),所以我估计是开始那个txt文件编码的问题,查看发现是Unicode编码(如何查看txt的编码呢,教你一个笨笨的办法:打开文件另存为,然后看到最下面的编码,默认选择的就是当前文档的编码格式),问题就出现在这里。问题找到了就好解决了,修改代码为:private String getProjectData()String data = null;try BufferedReader br = new BufferedReader(new InputStreamReader(new (file),"UTF-16");String str = br.readLine();data = str.split("t");br.close(); catch ( e) e.printStackTrace(); catch (IOException e) e.printStackTrace();return data;使用文件流读取,转换编码为“UTF-16”,这样乱码问题就解决了。归纳一下:txt文本文档有四种编码选项:ANSI、Unicode、Unicode big endian、UTF-8;默认应该是ANSI选项,就是系统的默认编码,一般是GBK,这种情况下用第一段代码解析是没有问题的,也不需要转码;其他格式就需要用第二段代码对应转码了,Unicode对应UTF-16,UTF-8就不用说了。关于获取txt文件编码,我们可能有时候需要用程序获取,动态判断,这里给一点资料,参考参考:ANSI: 无格式定义Unicode: 前两个字节为FFFE Unicode文档以0xFFFE开头Unicode big endian: 前两字节为FEFFUTF-8: 前两字节为EFBB UTF-8以0xEFBBBF开头用程序取出前几个字节并进行判断即可。package com.syscan.oa.util;import java.io.BufferedReader;import java.io.BufferedWriter;import java.io.File;import java.io.;import java.io.;import java.io.;import java.io.IOException;import java.util.ArrayList;import java.util.List;public class ReadWritTxtFileIO public static void main(String args) /ReadDate();/WriteDate();String path = "d:/"String str = writeToDat(path);System.out.println("str.length = " +str.length);for (int i = 0; i < str.length; i+) System.out.println(stri);String splitStr = stri.split("#");System.out.println("splitStr.length = " +splitStr.length);for(int j = 0; j < splitStr.length; j+)System.out.println(splitStrj);/* * 读取数据 */public static void ReadDate() String url = "e:/2.txt"try read = new (new );StringBuffer sb = new StringBuffer();char ch = new char1024;int d = read.read(ch);while (d != -1) String str = new String(ch, 0, d);sb.append(str);d = read.read(ch);System.out.print(sb.toString(); catch ( e) e.printStackTrace(); catch (IOException e) e.printStackTrace();/* * 写入数据 */SuppressWarnings("unchecked")public static void WriteDate() try = new File("D:/abc.txt");if () ();();BufferedWriter output = new BufferedWriter(new (file);ArrayList ResolveList = new ArrayList();for (int i = 0; i < 10; i+) ResolveList.add(Math.random() * 100);for (int i = 0; i < ResolveList.size(); i+) output.write(String.valueOf(ResolveList.get(i) + "n");output.close(); catch (Exception ex) System.out.println(ex);SuppressWarnings("unchecked")public static String writeToDat(String path) = new );List list = new ArrayList();String str = null;try BufferedReader bw = new BufferedReader(new (file);String line = null;/ 因为不知道有几行数据,所以先存入list集合中while (line = bw.readLine() != null) list.add(line);bw.close(); catch (IOException e) e.printStackTrace();/ 确定数组长度str = new Stringlist.size();for (int i = 0; i < list.size(); i+) String s = (String) list.get(i);stri = s;return str;4 / 4下载文档自由编辑打印

    注意事项

    本文(Java读取TXT文本文件乱码解决方案.doc)为本站会员(rrsccc)主动上传,三一文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一文库(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    经营许可证编号:宁ICP备18001539号-1

    三一文库
    收起
    展开