C#使用Log Parser 2.2 + MSchart打造简易Windows日志分析工具

前段时间做了一个简易的Windows日志分析工具(主要针对Windows系统日志SysEvent.Evt这个文件),主要是使用了Log Parser 2.2和MSchart控件,在此和大家分享一下!

首先是Log Parser 2.2,关于它的介绍我就不多说了,下载地址:http://www.microsoft.com/en-us/download/details.aspx?id=24659

第一步是安装Log Parser 2.2,然后新建一个C#窗体项目,在资源管理器中选中“引用”右键“添加引用”,选择Log Parser 2.2安装目录下的“LogParser.dll”

 添加引用

然后确定返回主窗体页面,添加一个button和一个dataGridView控件,在button的Click事件写入如下代码:

        private void button1_Click(object sender, EventArgs e)
        {
            string sql = @"SELECT EventID, TimeGenerated, SourceName, Message FROM E:\SysEvent.Evt";//此为系统日志文件路径
            DataTable dt = readFromEvt(sql);
            writeToDataBase(dt);
            dataGridView2.DataSource = dt;
            MessageBox.Show("读取完毕!");
        }
        public DataTable readFromEvt(string sql)
        {
            try
            {
                DataTable datat = new DataTable();
                datat.Columns.Add("事件ID", typeof(string));
                datat.Columns.Add("日期", typeof(string));
                datat.Columns.Add("来源", typeof(string));
                datat.Columns.Add("描述", typeof(string)); 
                // Instantiate the LogQuery object  
                LogQuery oLogQuery = new LogQuery();
                // Instantiate the Event Log Input Format object  
                EvtInputFormat oEvtInputFormat = new EvtInputFormat();
                // Set its "direction" parameter to "BW"  
                oEvtInputFormat.direction = "BW";
                // Create the query  
                string query = sql;
                // Execute the query  
                LogRecordSet oRecordSet = oLogQuery.Execute(query, oEvtInputFormat);
                while (!oRecordSet.atEnd())
                {
                    var itemData = oRecordSet.getRecord();
                    DataRow dr = datat.NewRow();
                    dr["事件ID"] = itemData.getValue("EventID").ToString();
                    dr["日期"] = itemData.getValue("TimeGenerated").ToString();
                    dr["来源"] = itemData.getValue("SourceName").ToString();
                    dr["描述"] = itemData.getValue("Message").ToString();
                    datat.Rows.Add(dr);
                    oRecordSet.moveNext();
                }
                
                // Close the recordset  
                oRecordSet.close();
                return datat;
            }
            catch (System.Runtime.InteropServices.COMException exc)
            {
                MessageBox.Show("Unexpected error: " + exc.Message);
                return null;
            } 
        }

至此已经完成了SysEvent.Evt日志文件内容的读取,这里是读取到一个DataTable并且绑定到dataGridView控件上,其中上面代码中还有一个函数writeToDataBase(dt);主要是将这些数据写到数据库中。

接下来是MSchart,VS2010自带这个控件,具体在工具箱数据栏下,名字是“Chart”,如果是VS2008的话还需要下载安装一下,下载地址:http://www.microsoft.com/en-us/download/details.aspx?id=14422,安装好以后,在“工具箱”右键“选择项”,“浏览”在Microsoft Chart Controls安装目录把Assemblies下的dll都添加进去(实际只用System.Windows.Forms.DataVisualization.dll),确定返回工具箱在数据栏下就可以看到“Chart”控件,拖拽一个到窗体上,然后再加入一个button,在button的Click事件写入如下代码:

private void button3_Click(object sender, EventArgs e)
        {
            DB db = new DB();
            string sql = @"select top 5 EventID,count(*) as Num from EvevtLog group by EventID order by count(*) desc";
            DataTable dt = db.GetDataTable(sql);
            dataGridView2.DataSource = dt;
            // Set series chart type
            Chart1.Series[0].ChartType = SeriesChartType.Bar;
            // Show as 3D
            Chart1.ChartAreas[0].Area3DStyle.Enable3D = true;
            // Draw as 3D Cylinder
            Chart1.Series[0]["DrawingStyle"] = "Cylinder";
            //Chart1.BackColor = Color.Azure; //图表背景色
            Chart1.Titles.Add("事件"); //图表标题
            //设置图表的数据源            
            Chart1.DataSource = dt;
            //设置图表Y轴对应项
            Chart1.Series[0].YValueMembers = "Num";
            //Chart1.Series[1].YValueMembers = "Volume2";
            //设置图表X轴对应项
            Chart1.Series[0].XValueMember = "EventID";
            Chart1.Series[0].IsValueShownAsLabel = true; //是否显示数据
            Chart1.Series[0].IsVisibleInLegend = false; //是否显示数据说明
            Chart1.Series[0].MarkerStyle = MarkerStyle.Circle; //线条上的数据点标志类型
            Chart1.Series[0].MarkerSize = 8; //标志大小
            Chart1.ChartAreas[0].AxisX.LineColor = Color.Blue; //X 轴颜色
            Chart1.ChartAreas[0].AxisY.LineColor = Color.Blue; //Y 轴颜色
            Chart1.ChartAreas[0].AxisX.LineWidth = 2; //X 轴宽度
            Chart1.ChartAreas[0].AxisY.LineWidth = 2; //Y 轴宽度
            Chart1.ChartAreas[0].AxisY.Title = "事件出现频率"; //Y 轴标题
            //绑定数据
            Chart1.DataBind(); 
        }

我这里面db.GetDataTable(sql);是从数据库里抽取数据出来展示,各位其实可以按需选择,关于展示部分,Chart控件很强大,我这里只做了一个统计展示的例子,其他的各位可以深入研究一下,最后看一下效果。

效果图
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值