zoukankan      html  css  js  c++  java
  • 彻底解决android读取中文txt的乱码(自动判断文档类型并转码

    原文:http://blog.csdn.net/handsomedylan/article/details/6138400

    public String convertCodeAndGetText(String str_filepath) {// 转码

                    File file = new File(str_filepath);
                    BufferedReader reader;
                    String text = "";
                    try {
                            // FileReader f_reader = new FileReader(file);
                            // BufferedReader reader = new BufferedReader(f_reader);
                            FileInputStream fis = new FileInputStream(file);
                            BufferedInputStream in = new BufferedInputStream(fis);
                            in.mark(4);
                            byte[] first3bytes = new byte[3];
                            in.read(first3bytes);//找到文档的前三个字节并自动判断文档类型。
                            in.reset();
                            if (first3bytes[0] == (byte) 0xEF && first3bytes[1] == (byte) 0xBB
                                            && first3bytes[2] == (byte) 0xBF) {// utf-8

                                    reader = new BufferedReader(new InputStreamReader(in, "utf-8"));

                            } else if (first3bytes[0] == (byte) 0xFF
                                            && first3bytes[1] == (byte) 0xFE) {

                                    reader = new BufferedReader(
                                                    new InputStreamReader(in, "unicode"));
                            } else if (first3bytes[0] == (byte) 0xFE
                                            && first3bytes[1] == (byte) 0xFF) {

                                    reader = new BufferedReader(new InputStreamReader(in,
                                                    "utf-16be"));
                            } else if (first3bytes[0] == (byte) 0xFF
                                            && first3bytes[1] == (byte) 0xFF) {

                                    reader = new BufferedReader(new InputStreamReader(in,
                                                    "utf-16le"));
                            } else {

                                    reader = new BufferedReader(new InputStreamReader(in, "GBK"));
                            }
                            String str = reader.readLine();

                            while (str != null) {
                                    text = text + str + "/n";
                                    str = reader.readLine();

                            }
                            reader.close();

                    } catch (FileNotFoundException e) {
                            // TODO Auto-generated catch block
                            e.printStackTrace();
                    } catch (IOException e) {
                            e.printStackTrace();
                    }
                    return text;
            }
    代码不难,觉得有用的可以顶一下。

  • 相关阅读:
    263 相对布局之3— 相对布局的综合案例
    262 相对布局之2— 相对布局的属性设置
    leetcode-----110. 平衡二叉树
    leetcode-----109. 有序链表转换二叉搜索树
    leetcode-----108. 将有序数组转换为二叉搜索树
    leetcode-----107. 二叉树的层次遍历 II
    leetcode-----106. 从中序与后序遍历序列构造二叉树
    leetcode-----105. 从前序与中序遍历序列构造二叉树
    leetcode-----104. 二叉树的最大深度
    leetcode-----103. 二叉树的锯齿形层次遍历
  • 原文地址:https://www.cnblogs.com/tc310/p/4015233.html
Copyright © 2011-2022 走看看