最近,我想从输出日志中提取某些数据。 这是日志文件的一部分:

2015-01-06 11:33:03 b.s.d.task [INFO] Emitting: eVentToRequestsBolt __ack_ack [-6722594615019711369 -1335723027906100557]
2015-01-06 11:33:03 c.s.p.d.PackagesProvider [INFO] ===---> Loaded package com.foo.bar
2015-01-06 11:33:04 b.s.d.executor [INFO] Processing received message source: eventToManageBolt:2, stream: __ack_ack, id: {}, [-6722594615019711369 -1335723027906100557]
2015-01-06 11:33:04 c.s.p.d.PackagesProvider [INFO] ===---> Loaded package co.il.boo
2015-01-06 11:33:04 c.s.p.d.PackagesProvider [INFO] ===---> Loaded package dot.org.biz

我决定使用Java8 Stream和Lambda Expression功能来实现。

读取文件

首先,我需要读取日志文件并将这些行放入Stream中:

Stream<String> lines = Files.lines(Paths.get(args[1]));

过滤相关行

我需要获取软件包名称并将其写入另一个文件。 并非所有行都包含我需要的数据,因此仅过滤相关行。

lines.filter(line -> line.contains("===---> Loaded package"))

解析相关行

然后,我需要解析相关行。 我首先将每一行拆分为一个字符串数组,然后采用该数组中的最后一个元素来完成此操作。 换句话说,我做了一个双重映射 。 首先是数组的一行,然后是字符串的数组。

.map(line -> line.split(" "))
.map(arr -> arr[arr.length - 1])

写入输出文件

最后一部分是获取每个字符串并将其写入文件。 那是终端操作。

.forEach(package -> writeToFile(fw, package));

writeToFile是我创建的方法。 原因是Java文件系统抛出IOException。 您不能在lambda表达式中使用检查的异常。

这是一个完整的示例(注意,我不检查输入)

import java.io.FileWriter;
import java.io.IOException;
import java.nio.file.Files;
import java.nio.file.Paths;
import java.util.Arrays;
import java.util.List;
import java.util.stream.Stream;public class App {public static void main(String[] args) throws IOException {Stream<String> lines = null;if (args.length == 2) {lines = Files.lines(Paths.get(args[1]));} else {String s1 = "2015-01-06 11:33:03 b.s.d.task [INFO] Emitting: adEventToRequestsBolt __ack_ack [-6722594615019711369 -1335723027906100557]";String s2 = "2015-01-06 11:33:03 b.s.d.executor [INFO] Processing received message source: eventToManageBolt:2, stream: __ack_ack, id: {}, [-6722594615019711369 -1335723027906100557]";String s3 = "2015-01-06 11:33:04 c.s.p.d.PackagesProvider [INFO] ===---> Loaded package com.foo.bar";String s4 = "2015-01-06 11:33:04 c.s.p.d.PackagesProvider [INFO] ===---> Loaded package co.il.boo";String s5 = "2015-01-06 11:33:04 c.s.p.d.PackagesProvider [INFO] ===---> Loaded package dot.org.biz";List<String> rows = Arrays.asList(s1, s2, s3, s4, s5);lines = rows.stream();}new App().parse(lines, args[0]);}private void parse(Stream<String> lines, String output) throws IOException {final FileWriter fw = new FileWriter(output);//@formatter:offlines.filter(line -> line.contains("===---> Loaded package")).map(line -> line.split(" ")).map(arr -> arr[arr.length - 1]).forEach(package -> writeToFile(fw, package));//@formatter:onfw.close();lines.close();}private void writeToFile(FileWriter fw, String package) {try {fw.write(String.format("%s%n", package));} catch (IOException e) {throw new RuntimeException(e);}}}

翻译自: https://www.javacodegeeks.com/2015/01/java-8-stream-and-lambda-expressions-parsing-file-example.html

Java 8流和Lambda表达式–解析文件示例相关推荐

  1. Java Stream 流常用方法 lambda 表达式实现交集、并集、差集、去重复并集等

    一般的javaList 交.并集采用简单的 removeAll retainAll 等操作,不过这也破坏了原始的javaList对象,采用java8 lambda表达式流操作则可以不影响原始list对 ...

  2. 精通lambda表达式:java多核编程_Java8 Lambda表达式和流操作如何让你的代码变慢5倍...

    有许许多多关于 Java 8 中流效率的讨论,但根据 Alex Zhitnitsky 的测试结果显示:坚持使用传统的 Java 编程风格--iterator 和 for-each 循环--比 Java ...

  3. java 拉姆表达式_Java8 lambda表达式10个示例

    Java 8 lambda表达式示例 转自importNew 原文链接 例1.用lambda表达式实现Runnable 我开始使用Java 8时,首先做的就是使用lambda表达式替换匿名类,而实现R ...

  4. Java 8 Lambda表达式10个示例【存】

    PS:不能完全参考文章的代码,请参考这个文件http://files.cnblogs.com/files/AIThink/Test01.zip 在Java 8之前,如果想将行为传入函数,仅有的选择就是 ...

  5. Java 8 新特性 lambda表达式

    / Created by Manager on 2021/4/1. Java 8 新特性 lambda表达式 StreamAPI 新日期 新注解 */ 视频连接 1https://www.bilibi ...

  6. java 函数式接口与lambda表达式的关系

    函数式接口与lambda表达式的关系 在java中,lambda表达式与函数式接口是不可分割的,都是结合起来使用的. 对于函数式接口,我们可以理解为只有一个抽象方法的接口,除此之外它和别的接口相比并没 ...

  7. Java 函数式编程和 lambda 表达式

    为什么要使用函数式编程 函数式编程更多时候是一种编程的思维方式,是种方法论.函数式与命令式编程的区别主要在于:函数式编程是告诉代码你要做什么,而命令式编程则是告诉代码要怎么做.说白了,函数式编程是基于 ...

  8. Java 8中使用Lambda表达式的策略模式

    策略模式是" 设计模式:可重用对象的元素"书中的模式之一 . 本书所述的策略模式的意图是: 定义一系列算法,封装每个算法,并使它们可互换. 策略使算法独立于使用该算法的客户端而变化 ...

  9. Java基础教程:Lambda表达式

    Java基础教程:Lambda表达式 引入Lambda Java 是一流的面向对象语言,除了部分简单数据类型,Java 中的一切都是对象,即使数组也是一种对象,每个类创建的实例也是对象.在 Java ...

最新文章

  1. Javascript使用三大家族和事件来DIY动画效果相关笔记(一)
  2. 计算机桌面ie图标无法删除,win7系统桌面ie图标无法删除怎么办
  3. React开发(260):react项目理解 dva中 console
  4. Jquery Highcharts 参数配置说明
  5. jquery查找父窗体id_js/jquery如何获取父窗口的元素?
  6. 详解ThroughTek P2P 供应链漏洞对数百万物联网设备的安全新风险
  7. 如何解决Backup Exec Remote Agent推送安装失败的问题
  8. [Avalon]如何实现自定义MarkupExtension.
  9. (转)Apache服务器使用.htaccess实现图片防盗链方法教程
  10. cs231n学习(1)图像分类器:KNN和线性分类器(上)
  11. iOS 更改导航栏返回button文字
  12. 引用阿里图标库(iconFont)的三种方式
  13. Nginx 配置根据表示进行PC与移动的跳转
  14. Cloudera 简介、安装和升级、管理、操作文档
  15. Intel编译器安装WRF-CMAQ
  16. 计算机视觉基础知识点(根据cs231n以及博客内容整理)
  17. [FPGA][基础模块]跨时钟域传播脉冲信号
  18. 信号与系统:拉式变换(s域)求解电路的零输入、零状态响应
  19. sublime如何设置为中文?
  20. KISSY基础篇乄KISSY之优化实例

热门文章

  1. mybatis简单案例源码详细【注释全面】——前期准备
  2. React中解决样式丢失问题
  3. 2015蓝桥杯省赛---java---B---8(饮料换购)
  4. Project编写功能点的规划时间
  5. python3.0什么时候发布的_Django 3.0 发布说明
  6. centos8上安装nginx
  7. redis-java客户端jedis测试
  8. 转:什么是 Base64编码
  9. html模板(base标签,meta标签,禁用浏览器缓存)+JSP自定义标签荔枝
  10. java集合—— 链表(java中的所有链表都是双向链表)