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

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

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

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

[java]
public class CSVLayout extends PatternLayout {

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

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

}
[/java]

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

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

[java]
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");
}

}
[/java]

同时在配置文件里加上:

[code]
log4j.appender.foo.layout.Header=foo,bar,xxx,yyy
[/code]

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

加载评论框需要翻墙