我想读取一个文本文件并根据列值对其进行拆分

时间:2018-08-28 09:40:11

标签: java dictionary filewriter

public class FileSplitter2 {

    public static void main(String[] args) throws IOException {

        String filepath = "D:\\temp\\test.txt";

        BufferedReader reader = new BufferedReader(new FileReader(filepath));
        String strLine;
        boolean isFirst = true;
        String strGroupByColumnName = "city";
        int positionOgHeader = 0;
        FileWriter objFileWriter;
        Map<String, FileWriter> groupByMap = new HashMap<String, FileWriter>();
        while ((strLine = reader.readLine()) != null) {
            String[] splitted = strLine.split(",");
            if (isFirst) {
                isFirst = false;
                for (int i = 0; i < splitted.length; i++) {
                    if (splitted[i].equalsIgnoreCase(strGroupByColumnName)) {
                        positionOgHeader = i;
                        break;
                    }
                }
            }
            String strKey = splitted[positionOgHeader];
            if (!groupByMap.containsKey(strKey)) {
                groupByMap.put(strKey, new FileWriter("D:/TestExample/" + strKey + ".txt"));
            }
            FileWriter fileWriter = groupByMap.get(strKey);
            fileWriter.write(strLine);
        }
        for (Map.Entry<String,FileWriter> entry : groupByMap.entrySet()) {
        entry.getKey();
        }

    }
}

这是我的代码。我没有得到适当的结果。该文件包含10列,第5列是“ city”。档案中有10个不同的城市。我需要将每个城市分割成一个单独的文件。

1 个答案:

答案 0 :(得分:0)

您没有在所有close上调用FileWriter,因此数据可能不会刷新到文件中。

请参见FileWriter is not writing in to a file

在处理结束时,

 groupByMap.values().forEach(fileWriter -> {
        try {
            fileWriter.close();
        } catch (IOException e) {
            e.printStackTrace(); //Add appropriate error handling
        }
    });

您的代码中有一个错误。您需要将if (isFirst)块之后的语句移动到else块中。否则,它也会创建一个city.txt文件。