joe601269914 2017-03-31 11:56 采纳率: 0%
浏览 1984

java 读写txt文件乱码

最近从网上爬下一些音乐网页,用HTMLParser 分析的时候出现了乱码问题,好不容易解决以后,获得了一些音乐信息的txt文件。然而在建立索引的时候,需要把这些txt文件的文件名(由歌手和歌名两部分组成)截取出来写入另一个txt文件,此时竟然出现了乱码问题

结果控制台输出的结果没有任何问题
但是在word.txt文件里中文是乱码的

各种尝试 好像都没奏效。。。

 public class BuildWordVacabulary {

    private String wordvacabularypath = null;                  //新的txt地址

    private ArrayList wordlist = new ArrayList();

    public void loadProductFromDirectory(String[] dirs) throws IOException {
        String fullname = null;
        try {
            if (wordvacabularypath == null) {
                throw new IOException("  ");
            }

            for (int i = 0; i < dirs.length; i++) {

                String folder = dirs[i];
                File foo = new File(folder);
                String[] files = foo.list();

                for (int j = 0; j < files.length; j++) {
                    File f = new File(foo, files[j]);

                     fullname = f.getName();                                   //遍历文件,获取所有txt文件的文件名

                    String type = fullname.substring(fullname.indexOf("-") + 1
                            ,fullname.indexOf(".txt"));                                                 //获取歌手
                    String name = fullname.substring(0, fullname.indexOf("-"));   //获取歌名

                if (!wordlist.contains(type)) {
                    wordlist.add(type);
                }

                    if (!wordlist.contains(name)) {
                        wordlist.add(name);
                    }

                }

            }

            Collections.sort(wordlist);
            writeToFile();
        } catch (Exception e) {
            System.out.println(fullname);
            e.printStackTrace();
        }
    }

    private void writeToFile() throws IOException {

        BufferedWriter writer = new BufferedWriter(new FileWriter(
                wordvacabularypath));

        for (int i = 0; i < wordlist.size(); i++) {
            String type = (String)wordlist.get(i);
            writer.write(type);                                                //写入
//  writer.write(name);                                            
            writer.newLine();
            System.out.println(type); 
        }

        writer.close();

    }

    public void setWordvacabularyPath(String wordvacabularypath) {
        this.wordvacabularypath = wordvacabularypath;
    }

    public static void main(String[] args) throws IOException {
        BuildWordVacabulary builder = new BuildWordVacabulary();
        builder.setWordvacabularyPath("//root//Documents//word.txt");          //新的txt文件
        builder.loadProductFromDirectory(new String[] { "//root//Documents//mp3//" });   //遍历的文件
    }

}
  • 写回答

4条回答 默认 最新

  • 007Detective 2017-03-31 12:27
    关注

    要不修改一下txt文件的编码格式?

    评论

报告相同问题?

悬赏问题

  • ¥15 matlab数字图像处理频率域滤波
  • ¥15 在abaqus做了二维正交切削模型,给刀具添加了超声振动条件后输出切削力为什么比普通切削增大这么多
  • ¥15 ELGamal和paillier计算效率谁快?
  • ¥15 file converter 转换格式失败 报错 Error marking filters as finished,如何解决?
  • ¥15 ubuntu系统下挂载磁盘上执行./提示权限不够
  • ¥15 Arcgis相交分析无法绘制一个或多个图形
  • ¥15 关于#r语言#的问题:差异分析前数据准备,报错Error in data[, sampleName1] : subscript out of bounds请问怎么解决呀以下是全部代码:
  • ¥15 seatunnel-web使用SQL组件时候后台报错,无法找到表格
  • ¥15 fpga自动售货机数码管(相关搜索:数字时钟)
  • ¥15 用前端向数据库插入数据,通过debug发现数据能走到后端,但是放行之后就会提示错误