按行读取批量日志文件,并将一部分数据写入Excel表格

按行读取批量日志文件,并将一部分数据写入Excel表格

前言

第一次写博客,也是第一次写读取文件导出为Excel表格的案例,其中去重,我试过很多方法,包括list集合循环去重,双重map去重,数组等,租最后才想到将两个判重的条件拼接作为key,最后导出表格时再遍历取出并截取。所以下面代码中许多注释的内容都是测试所使用的,有兴趣的可以看看,有好的建议可以提出来,一起学习!

1.需求

Java编写脚本,处理批量日志文件。可以读取某个文件夹下所有文件和子文件夹内的日志文件。以本次代码需求为例:需要读取日志文件中的IP、OID、oidsObj所对应的数据,并根据IP、OID两个元素组合判重,去掉重复的数据,在导入Excel表格。

2.解决思路

1、按行读取给定文件夹下所有文件;
2、对每一行读取的数据经常处理,取包含三个字段对应的一行数据temp.contains(“peerAdd为=”)、temp.contains(“OID==”)、temp.contains(“oidsObj==”);
3、对所需的每行数据进行截取,(String[] str = temp.split("=====================");
str = str[1].split("/");)获得IP、OID、oidsObj;
4、把截取的IP、OID、oidsObj分别存入三个集合中以便之后便利取出作为map集合的组合key;
5、以一个文件为单位,将IP、OID拼接作为key,oidsObj作为value存入map集合;
6、最后进行导入Excel表格。

3.源代码

package file;

import java.io.BufferedReader;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;

import org.apache.poi.hssf.userm
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值