2 u010235241 u010235241 于 2013.09.06 17:01 提问

【求助】怎么用Java读txt文件,根据其中的条件,输出一个csv文件?(具体情况见内容)

用Java,
读txt文件(根据Eclipse软件的下方的console改成的log.txt)
——————————————————————————————————————
例:
[2013-08-26 10:45:45,042] ERROR does not exist.
[2013-08-26 14:43:09,145] ERROR Certification failed.
[2013-08-26 14:43:09,145] ERROR Certification failed.
[2013-08-26 14:43:10,973] ERROR Certification failed.
[2013-08-26 14:43:33,285] ERROR Certification failed.
[2013-08-28 09:23:12,920] INFO Login succeeded.User ID=[CSDN123]
[2013-09-02 10:13:32,793] INFO Login succeeded.User ID=[CSDN123]
[2013-09-02 10:36:05,050] INFO Login succeeded.User ID=[CSDN123]
[2013-09-02 10:48:26,407] INFO Login succeeded.User ID=[CSDN123]
——————————————————————————————————————
从左至右分别是:
[时间][级别(有Error、Info、Warning等)][错误信息]

然后,根据时间(如:2013-08-26至2013-09-01),
将其中这些行的信息写成csv文件
(格式是:时间,级别(有ERROR、INFO、WARNING等),错误信息)。

或者,根据级别(如:级别是ERROR),
将这些行的信息写成csv文件,格式同上。

小弟初来乍到,求大神帮忙,实现此功能,万分感谢!

2个回答

u012388497
u012388497   2015.08.10 14:44
Java没有这些类库,直接处理可行但非常麻烦。这种情况用润乾集算器要方便得多,将日志解析成二维行列的序表,并输出csv,脚本如下:

A1 =file("E:\log.txt").import@i()

A2 =A1.(~.array(" ")).new(~(1).string():time,~(2):level,~.to(3,).string(" "):content)

A3 =A2.select(time>="2013-08-26" && time<="2013-09-01")

A4 =file("E:\result.csv").export@t(A3;",")


这段代码很容易嵌入JAVA程序中使用,可参考http://blog.raqsoft.cn/?p=5805 ,更多例子可参考http://blog.raqsoft.cn/?p=4792

oyljerry
oyljerry   Ds   Rxr 2015.08.10 14:51

http://www.cnblogs.com/manongxiaojiang/archive/2012/10/13/2722068.html

然后自己一行行读取,再按规律解析。

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!