通过Log4j生成CSV格式日志时自动插入表头处理方法

转载:http://ju.outofmemory.cn/entry/141660

在开发某个类似报表的功能时,感觉用log4j直接按天滚动生成csv格式的文件很方便,于是研究了一下如何在日志滚动时自动插入表头的方法。

log4j的各种layout都派生自org.apache.log4j.Layout这个抽象类。Layout有一个getHeader()方法,默认返回null,因此只要实现一个你使用的*Layout的子类,重写getHeader方法就可以了。

比如我用的是org.apache.log4j.PatternLayout,所以我的实现类是这样子:

public class CSVLayout extends PatternLayout {

    private static final String HEADER = "column1,column2,column3,column4";

    @Override
    public String getHeader() {
        return HEADER + System.getProperty("line.separator");
    }
}

同理还有getFooter()方法,可以在文件尾部追加一行内容。

如果你愿意把header放在log4j配置文件里,则可以这样实现:

public class HeaderLayout extends PatternLayout{
	private String header;
	public void setHeader(String header){
		this.header = header;
	}
	public String getHeader(){
		return header+System.getProperty("line.separator");
	}

}

同时在配置文件里加上:

log4j.appender.foo.layout.Header=foo,bar,xxx,yyy

这样就可以实现log4j每产生一个新的日志文件都在第一行追加指定内容了。不过有一个不足就是:如果重启程序,则会在当天的文件中产生额外的header。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值