Java8使用Function读取文件

 更新时间:2024年12月26日 09:53:18   作者:ByteX  
这篇文章主要为大家详细介绍了Java8如何使用Function读取文件,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以参考一下

首先,我们需要一个 FileCloseAble 类来处理文件写入操作。

import java.util.ArrayList;
import java.util.function.Consumer;
import java.util.List;

public class FileCloseAble<T> implements AutoCloseable {
    private Consumer<List<T>> writer;
    private int pageSize;
    private List<T> buffer;

    public FileCloseAble(Consumer<List<T>> writer, int pageSize) {
        this.writer = writer;
        this.pageSize = pageSize;
        this.buffer = new ArrayList<>(Math.max(1, pageSize));
    }

    public void add(T element) {
        buffer.add(element);
        if (buffer.size() >= pageSize) {
            flush();
        }
    }

    private void flush() {
        if (!buffer.isEmpty()) {
            writer.accept(new ArrayList<>(buffer));
            buffer.clear();
        }
    }

    @Override
    public void close() {
        flush();
    }
}

FileContext 类来存储文件的上下文信息。

public class FileContext {
    private File file;
    private Charset charset;
    private int skipHeader;
    private String batchDate;
    private int pageSize;
    private boolean deleteFlag;
    private String filterLineHeader;

    // 构造函数、getter 和 setter 省略

    public File getFile() {
        return file;
    }

    public void setFile(File file) {
        this.file = file;
    }

    public Charset getCharset() {
        return charset;
    }

    public void setCharset(Charset charset) {
        this.charset = charset;
    }

    public int getSkipHeader() {
        return skipHeader;
    }

    public void setSkipHeader(int skipHeader) {
        this.skipHeader = skipHeader;
    }

    public String getBatchDate() {
        return batchDate;
    }

    public void setBatchDate(String batchDate) {
        this.batchDate = batchDate;
    }

    public int getPageSize() {
        return pageSize;
    }

    public void setPageSize(int pageSize) {
        this.pageSize = pageSize;
    }

    public boolean isDeleteFlag() {
        return deleteFlag;
    }

    public void setDeleteFlag(boolean deleteFlag) {
        this.deleteFlag = deleteFlag;
    }

    public String getFilterLineHeader() {
        return filterLineHeader;
    }

    public void setFilterLineHeader(String filterLineHeader) {
        this.filterLineHeader = filterLineHeader;
    }
}

FileHandler 类

import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.NoArgsConstructor;
import lombok.extern.slf4j.Slf4j;

import java.io.File;
import java.nio.file.Files;
import java.nio.file.Paths;
import java.util.List;
import java.util.function.BiFunction;
import java.util.function.Consumer;
import java.util.stream.Stream;

@Builder
@AllArgsConstructor
@NoArgsConstructor
@Slf4j
public class FileHandler<T, R> {

    private FileContext context;
    private BiFunction<String, String, T> reader; // 读逻辑
    private Consumer<List<T>> writer;// 写逻辑
    private LineFilter lineFilter; // 新增过滤逻辑

    public void execute() throws Exception {
        File file = context.getFile();
        try (
                Stream<String> streams = Files.lines(Paths.get(file.getPath()), context.getCharset());
                FileCloseAble<T> files = new FileCloseAble<>(writer, context.getPageSize())
        ) {
            streams.skip(context.getSkipHeader())
                    .filter(lineFilter.getLinePredicate())
                    .map(e -> reader.apply(e, context.getBatchDate()))
                    .forEach(files::add);
        } catch (Exception e) {
            log.error("解析文件失败: file: {}, error: {}", file, e);
            throw new Exception("文件处理异常", e);
        } finally {
            deleteFileIfNecessary(file);
        }
    }

    private void deleteFileIfNecessary(File file) {
        if (context.isDeleteFlag() && file.exists()) {
            try {
                boolean deleted = Files.deleteIfExists(file.toPath());
                if (deleted) {
                    log.info("文件已删除: {}", file);
                } else {
                    log.info("文件不存在,无法删除: {}", file);
                }
            } catch (Exception e) {
                log.error("删除文件失败: file: {}, error: {}", file, e);
            }
        }
    }
}

定义一个过滤函数接口

定义一个 Predicate 接口,用于表示每一行的过滤逻辑。

import java.util.function.Predicate;

public interface LineFilter {
    Predicate<String> getLinePredicate();
}

实现 LineFilter 接口

创建一个实现了 LineFilter 接口的类,用于定义具体的过滤逻辑。

import java.util.function.Predicate;

public class CustomLineFilter implements LineFilter {
    private String filterLineHeader;

    public CustomLineFilter(String filterLineHeader) {
        this.filterLineHeader = filterLineHeader;
    }

    @Override
    public Predicate<String> getLinePredicate() {
        return line -> !line.startsWith(filterLineHeader);
    }
}

使用 FileHandler 类

import java.io.File;
import java.nio.charset.StandardCharsets;
import java.util.List;
import java.util.function.BiFunction;
import java.util.function.Consumer;

public class FileHandlerExample {
    public static void main(String[] args) {
        // 创建文件上下文
        FileContext context = new FileContext();
        File file = new File("D:\\temp\\testwrite.txt");
        context.setFile(file);
        context.setCharset(StandardCharsets.UTF_8);
        context.setSkipHeader(0);
        context.setBatchDate("20220101");
        context.setPageSize(100);
        context.setDeleteFlag(false);

        // 定义解析方法
        BiFunction<String, String, String> reader = (line, batchDate) -> line.trim();

        // 定义写入方法
        Consumer<List<String>> writer = list -> {
            for (String s : list) {
                System.out.println(s);
            }
        };

        // 创建自定义过滤逻辑
        LineFilter lineFilter = new CustomLineFilter("#");

        // 创建 FileHandler 实例
        FileHandler<String, Void> fileHandler = FileHandler.<String, Void>builder()
                .context(context)
                .reader(reader)
                .writer(writer)
                .lineFilter(lineFilter) // 设置过滤逻辑
                .build();

        // 执行文件处理
        try {
            fileHandler.execute();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

可以愉快的读写文件啦

到此这篇关于Java8使用Function读取文件的文章就介绍到这了,更多相关Java8 Function读取文件内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Java二叉树遍历与递归详解(从入门到精通)

    Java二叉树遍历与递归详解(从入门到精通)

    二叉树是一棵空树,或者是一棵由一个根节点和两棵互不相交的,分别称作根的左子树和右子树组成的非空树,这篇文章主要介绍了Java二叉树遍历与递归的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2026-03-03
  • SpringBoot中整合JodConverter实现文件在线预览功能

    SpringBoot中整合JodConverter实现文件在线预览功能

    Spring Boot JodConverter是一个基于Spring Boot框架的文档转换工具,它使用JodConverter库来实现文档格式之间的转换,本文主要介绍了SpringBoot中整合JodConverter实现文件在线预览功能,需要的朋友可以参考下
    2024-04-04
  • IDEA 2021.2 激活教程及启动报错问题解决方法

    IDEA 2021.2 激活教程及启动报错问题解决方法

    这篇文章主要介绍了IDEA 2021.2 启动报错及激活教程,文章开头给大家介绍了idea2021最新激活方法,关于idea2021启动报错的问题小编也给大家介绍的非常详细,需要的朋友可以参考下
    2021-10-10
  • java获取当前时间的四种方法代码实例

    java获取当前时间的四种方法代码实例

    这篇文章主要介绍了java获取当前时间的四种方法代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-09-09
  • 详解spring中使用Elasticsearch的代码实现

    详解spring中使用Elasticsearch的代码实现

    本篇文章主要介绍了详解spring中使用Elasticsearch的代码实现,具有一定的参考价值,有兴趣的可以了解一下
    2017-05-05
  • 我们来说说Java LockSupport 的 park 和 unpark

    我们来说说Java LockSupport 的 park 和 unpa

    LockSupport是JDK底层线程阻塞工具,通过park/unpark实现线程阻塞与唤醒,避免死锁,与Object的wait/notify相比,无需监视器,支持先unpark后park,且更精确控制线程状态,是AQS等同步器的核心基础,本文介绍Java LockSupport 的 park 和 unpark,感兴趣的朋友一起看看吧
    2025-07-07
  • kaptcha验证码使用方法详解

    kaptcha验证码使用方法详解

    这篇文章主要为大家详细介绍了kaptcha验证码的使用方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-12-12
  • 从dubbo源码分析qos-server端口冲突问题及解决

    从dubbo源码分析qos-server端口冲突问题及解决

    这篇文章主要介绍了从dubbo源码分析qos-server端口冲突问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-02-02
  • Flutter实现容器组件、图片组件 的代码

    Flutter实现容器组件、图片组件 的代码

    容器组件(Container)可以理解为在Android中的RelativeLayout或LinearLayout等,在其中你可以放置你想布局的元素控件,从而形成最终你想要的页面布局。这篇文章主要介绍了Flutter实现容器组件、图片组件 的代码,需要的朋友可以参考下
    2019-07-07
  • Java五子棋单机版源码分享

    Java五子棋单机版源码分享

    这篇文章主要为大家分享了Java五子棋单机版源码,JavaGUI编写单机版五子棋,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-03-03

最新评论