Java:对文件A.txt内部数据逐行排序,并写入B.txt

1.执行结果要求如图:

这里写图片描述
这里写图片描述

2.代码:

import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.io.UnsupportedEncodingException;
import java.util.List;
import java.util.Vector;

public class ReadFile {

    public static void main(String[] args) {
        File file = new File("test.txt");
        if (file.exists()) {

            try {
                FileInputStream fis = new FileInputStream(file);
                InputStreamReader isr = new InputStreamReader(fis, "UTF-8");
                BufferedReader br = new BufferedReader(isr);

                File newfile = new File("sort_test.txt"); // 如果文件不存在下一步会创建出来
                FileOutputStream fos = new FileOutputStream(newfile);
                OutputStreamWriter osw = new OutputStreamWriter(fos, "UTF-8");
                BufferedWriter bw = new BufferedWriter(osw);

                String str;
                String[] line;
                str = br.readLine();
                int temp;

                while (str != null) {
                    line = str.split("\\|");
                    int[] intArray = new int[line.length];
                    for (int i = 0; i < line.length; i++) {
                        intArray[i] = Integer.parseInt(line[i]);
                    }

                    for (int m = 0; m < intArray.length - 1; m++) {
                        for (int n = 0; n < intArray.length - m - 1; n++) {
                            if (intArray[n] > intArray[n + 1]) {
                                temp = intArray[n];
                                intArray[n] = intArray[n + 1];
                                intArray[n + 1] = temp;
                            }
                        }
                    }

                    List<String> lists = new Vector<String>();
                    for (int j = 0; j < intArray.length; j++) {
                        lists.add(String.valueOf(intArray[j]));
                    }

                    for (int j = 0; j < lists.size(); j++) {
                        bw.write("|" + lists.get(j));
                    }
                    bw.write("\n");
                    str = br.readLine();

                }

                br.close();
                isr.close();
                fis.close();
                bw.close();
                osw.close();
                fos.close();

            } catch (FileNotFoundException e) {
                e.printStackTrace();
            } catch (UnsupportedEncodingException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }

}
  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
读取大小为40G的txt文件需要使用一些特殊的技巧来避免内存溢出问题,可以采用逐行读取的方式。以下是一个基本的Java代码示例: ```java import java.io.*; import java.util.*; public class SortLargeTxtFile { public static void main(String[] args) throws IOException { String inputFilePath = "largefile.txt"; String outputFilePath = "sortedfile.txt"; BufferedReader reader = new BufferedReader(new FileReader(inputFilePath)); List<String> lines = new ArrayList<>(); String line; while ((line = reader.readLine()) != null) { lines.add(line); } reader.close(); Collections.sort(lines); BufferedWriter writer = new BufferedWriter(new FileWriter(outputFilePath)); for (String sortedLine : lines) { writer.write(sortedLine); writer.newLine(); } writer.close(); } } ``` 该代码使用了`BufferedReader`逐行读取txt文件,并将每一行存储在一个`List`,然后使用`Collections.sort`方法对这个`List`进行排序,最后使用`BufferedWriter`逐行写入到输出文件。 但是,由于要读取文件大小非常大,这个程序可能会耗费很长时间,并且可能会因为内存不足而崩溃。因此,你可能需要采用一些更高效的算法和数据结构来处理这个问题。比如,可以采用外部排序(External sorting)的方法,将文件分割成若干个小文件,对每个小文件进行排序,最后将这些小文件合并成一个文件。这个过程可以使用归并排序(Merge sort)或快速排序(Quick sort)等算法来实现。但是,这个方法的实现比较复杂,需要一定的编程技巧和时间成本。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值