网站首页 > 精选教程 正文
Java读取文本文件的几个方法。
读到内存(适合小文件)
Guava方法:
Files.readLines(new File(path), Charsets.UTF_8);
Apache Commons IO方法:
FileUtils.readLines(new File(path));
这种方法的问题在于所有内容都保留在内存中。如果文件太大,这将迅速导致OutOfMemory错误。
此外,通常我们并不需要把一个大文件一次性全部读出来。 一方面,我们可能会对文件逐行做处理;一方面即便是直接显示也会分段呈现。想象一下,一次性给前端(不管是web还是桌面)返回1G的数据,怎么显示?
文件流Scanner
try(Scanner scanner = new Scanner(new File(pathname))) { while ( scanner.hasNextLine() ) { String line = scanner.nextLine(); // 逐行处理 } }
Apache Commons IO的Stream
LineIterator it = FileUtils.lineIterator(theFile, "UTF-8"); try { while (it.hasNext()) { String line = it.nextLine(); // 逐行处理 } } finally { LineIterator.closeQuietly(it); }
Java8的Stream
Files.lines(Paths.get(pathname));
利用Files.lines()得到一个Stream,然后逐行处理。
进阶
- 读取文件总行数
// 总行数 long lineCount = Files.lines(Paths.get(pathname)).count();
- 读取指定行或起止行
try (Stream<String> lines = Files.lines(path)) { List<String> list = lines.skip( 1000 ).limit(10).collect(Collectors.toList()); } catch (IOException e) { e.printStackTrace(); }
如上,读取1001行到1010行。
利用上面这两段代码,可以用类似分页的方式来读取整个文件。
总页数 = 总行数 / 每页条数 + (总行数 % 每页条数 == 0 ? 0 : 1); 每页内容 = lines.skip( (第几页-1)*每页条数 ).limit(每页条数);
猜你喜欢
- 2024-12-01 从零学大数据之Java篇第二十五章:文件操作详解
- 2024-12-01 Java中读取File文件内容转为String类型
- 2024-12-01 JAVA文件基本操作
- 2024-12-01 Java如何获取一个文本文件的编码(格式)信息呢?
- 2024-12-01 灵魂一问:一个Java文件的执行全部过程你确定都清楚吗?
- 2024-12-01 几种获取resources目录下的文件方式
- 2024-12-01 读取Spring配置文件的方法(Spring读取资源文件)
- 2024-12-01 JAVA中的文件操作2-如何读写文件
- 2024-12-01 Java高效读取纯文本文件
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- nginx反向代理 (57)
- nginx日志 (56)
- nginx限制ip访问 (62)
- mac安装nginx (55)
- java和mysql (59)
- java中final (62)
- win10安装java (72)
- java启动参数 (64)
- java链表反转 (64)
- 字符串反转java (72)
- java逻辑运算符 (59)
- java 请求url (65)
- java信号量 (57)
- java定义枚举 (59)
- java字符串压缩 (56)
- java中的反射 (59)
- java 三维数组 (55)
- java插入排序 (68)
- java线程的状态 (62)
- java异步调用 (55)
- java中的异常处理 (62)
- java锁机制 (54)
- java静态内部类 (55)
- java怎么添加图片 (60)
- java 权限框架 (55)
本文暂时没有评论,来添加一个吧(●'◡'●)