读取中兴3G告警log告警文件到集合
1、文件格式
ALARM_ID=102305_404205 EVENT_TIME=-- :: NOTIFICATION_TYPE= MANAGED_OBJECT_INSTANCE=NodeId=,BssId=,BtsId=,RackId= PERCEIVED_SEVERITY= ALARM_TYPE= PROBABLE_CAUSE= SPECIFIC_PROBLEM=直流电压低于47V(RRU干结点监控) ADDITIONAL_TEXT=AlarmCode(),AlarmInfo(The subsystem No. , RRU_INFO=[RRU ID=, Alias=武隆中兴隧道RRU0_江口支局, Type=RRU])
2、创建实体类
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace LteAlarmAnalysis.Entities
{
/// <summary>
/// 中兴 3G 告警Ftp下载数据实体
/// 日期 : 2016年8月16日
/// 作者 : 老郑
///
/// ALARM_ID=102301_928516
/// EVENT_TIME=2016-08-16 09:59:35
/// NOTIFICATION_TYPE=5
/// MANAGED_OBJECT_INSTANCE=NodeId=102301,BssId=0,BtsId=38,RackId=2
/// PERCEIVED_SEVERITY=6
/// ALARM_TYPE=4
/// PROBABLE_CAUSE=550
/// SPECIFIC_PROBLEM=直流电压低于51V或交流故障(RRU干结点监控)
/// ADDITIONAL_TEXT=AlarmCode(1005019),AlarmInfo(The subsystem No. is 9, RRU_INFO=[RRU ID=4, Alias=万州石桥毛岭RRU_武陵支局, Type=RRU])
/// </summary>
public class AlarmEntities3GZte
{
public string ALARM_ID { get; set; }
public string EVENT_TIME { get; set; }
public string NOTIFICATION_TYPE { get; set; }
public string MANAGED_OBJECT_INSTANCE { get; set; }
public string PERCEIVED_SEVERITY { get; set; }
public string ALARM_TYPE { get; set; }
public string PROBABLE_CAUSE { get; set; }
public string SPECIFIC_PROBLEM { get; set; }
public string ADDITIONAL_TEXT { get; set; }
}
}
3、数据读取到List集合
/// <summary>
/// 读取告警转换为集合
/// </summary>
private IList<AlarmEntities3GZte> Alarm2AlarmEntities3GZte()
{
IList<AlarmEntities3GZte> list = new List<AlarmEntities3GZte>();
try
{
TaskConfig.SpanTime = Stopwatch.StartNew();
var reAlarmFiles = Directory.GetFiles(TaskConfig.SavePath, TaskConfig.FileMatch);
AlarmEntities3GZte alarm = null;
], Encoding.Default);
foreach (string line in lines)
{
)
{
alarm = new AlarmEntities3GZte();
}
if (line != null && !"".Equals(line.Trim()))
{
alarm = Line2Property(line, alarm);
}
&& alarm != null)
{
list.Add(alarm);
}
}
WriteMessage.PrintMassage(MessageType.Success, String.Format("解析中兴告警文件成功,共解析出小区发生不同告警数据量:{0} 条,总数据量为:{1} 条,共耗时:{2}毫秒"
, list.Count, list.Count, TaskConfig.SpanTime.ElapsedMilliseconds));
}
catch (Exception ex)
{
WriteMessage.PrintMassage(MessageType.Error, String.Format("解析中兴告警文件失败,错误信息:{0}", ex));
Environment.Exit(-);
}
return list;
}
private AlarmEntities3GZte Line2Property(string line, AlarmEntities3GZte alarm)
{
if (alarm == null)
{
alarm = new AlarmEntities3GZte();
}
System.Reflection.PropertyInfo[] properties = alarm.GetType().GetProperties(System.Reflection.BindingFlags.Instance | System.Reflection.BindingFlags.Public);
)
{
return alarm;
}
foreach (System.Reflection.PropertyInfo item in properties)
{
string name = item.Name;
object value = item.GetValue(alarm, null);
)
{
item.SetValue(alarm, line.Replace(name + "=", ""), null);
break;
}
}
return alarm;
}
读取中兴3G告警log告警文件到集合的更多相关文章
- 2018.2.12 PHP 如何读取一亿行的大文件
PHP 如何读取一亿行的大文件 我们可能在很多场景下需要用 PHP 读取大文件,之后进行处理,如果你没有相关的经验可以看下,希望能给你带来一些启发. 模拟场景 我们有一个 1亿 行,大小大概为 3G ...
- [转]Android输出Log到文件
前言:开发中遇到mx4这款机型Eclipse联调不上,logcat看不了,需要输出生成文件查看调试信息.网上搜了下,功能很完善了.startService和过滤输出信息需要自己添加设置,另外注意添加权 ...
- [转]读取assets目录下的数据库文件
在做Android应用的时候,不可避免要用到数据库.但是当我们把应用的apk部署到真机上的时候,已经创建好的数据库及其里边的数据是不能随着apk一起安装到真机上的. (PS:这篇博客解决了我前面博客中 ...
- Android将Log写入文件
为什么要将Log写入文件 运行应用程序的时候,大多数是不会连接着IDE的: 而当应用程序崩溃时,我们需要收集复现步骤,在设备上复现,并进行Debug: 而由于Android手机的多样性,有些问题是某个 ...
- .net core 读取本地指定目录下的文件
项目需求 asp.net core 读取log目录下的.log文件,.log文件的内容如下: xxx.log ------------------------------------------beg ...
- SpringBoot读取Linux服务器某路径下文件\读取项目Resource下文件
// SpringBoot读取Linux服务器某路径下文件 public String messageToRouted() { File file = null; try { file = Resou ...
- 前端H5中JS用FileReader对象读取blob对象二进制数据,文件传输
HTML5中的Blob对象只是二进制数据的容器,本身并不能操作二进制,故本篇将对其操作对象FileReader进行介绍. FileReader FileReader主要用于将文件内容读入内存,通过一系 ...
- 面试题-python 如何读取一个大于 10G 的txt文件?
前言 用python 读取一个大于10G 的文件,自己电脑只有8G内存,一运行就报内存溢出:MemoryError python 如何用open函数读取大文件呢? 读取大文件 首先可以自己先制作一个大 ...
- ubuntu /var/log/下文件介绍
本文简单介绍ubuntu /var/log/下各个日志文件,方便出现错误的时候查询相应的log /var/log/alternatives.log -更新替代信息都记录在这个文件中 /var/lo ...
随机推荐
- (Problem 36)Double-base palindromes
The decimal number, 585 = 10010010012(binary), is palindromic in both bases. Find the sum of all num ...
- 通过原生js的ajax或jquery的ajax获取服务器的时间
在实际的业务逻辑中,经常是与时间相关的,而前端能获得的时间有两个:客户端的时间,服务器的时间. 客户端时间通过 javascript中的Date对象可以获取,如 var dt = new Date() ...
- IM-即时通讯技术概述
IM-即时通讯技术概述 简述 即时通讯技术(IM)支持用户在线实时交谈.如果要发送一条信息,用户需要打开一个小窗口,以便让用户及其朋友在其中输入信息并让交谈双方都看到交谈的内容.大多数常用的即时通讯发 ...
- gzip解压压缩的字符串数据
import urllib2 from StringIO import StringIO import gzip def loadData(url): request = urllib2.Reques ...
- 质因数分解的rho以及miller-rabin
一.前言 质因数分解,是一个在算法竞赛里老生常谈的经典问题.我们在解决许多问题的时候需要用到质因数分解来辅助运算,而且质因数分解牵扯到许许多多经典高效的算法,例如miller-rabin判断素数算法, ...
- poj 1084 Brainman(归并排序)
题目链接:http://poj.org/problem?id=1804 思路分析:序列的逆序数即为交换次数,所以求出该序列的逆序数即可. 根据分治法思想,序列分为两个大小相等的两部分,分别求子序列的逆 ...
- c++的引用(二)
/*按地址传递*/ #include <iostream> using namespace std; void swap(int *a, int *b) { int c; c = *a; ...
- iOS 常用开源代码整理
本文章不定期整理. 1.AFNetworking AFNetworking 采用 NSURLConnection + NSOperation, 主要方便与服务端 API 进行数据交换, 操作简单, 功 ...
- Java字节码中的方法调用
invokestatic,用于static修饰的方法.任何时候调用的时候只需要类名+方法名即可,无需new.JVM直接将其映射到方法区,执行速度极快.当该方法需要参数的时候,invokestatic会 ...
- static timing analysis 基础
此博文依据 特权同学在电子发烧友上的讲座PPT进行整理而成. static timing analysis 静态时序分析基础 过约束:有不必要的约束,或者是约束不能再某一情况下满足.——约束过头了 ...