读取.Log文件中的特定行

时间:2014-04-25 09:30:30

标签: c#

我有一个日志文件,我正在阅读不同的对象。一个对象从包含单词“Announce message”的Line开始,以下行包含属于该消息的数据。此条目在包含单词“Disposed”的行停止。 我想要阅读这两行中包含某些单词的所有数据。

我当前使用的是Dictionary,因为带有“Announce message”的行也包含一个UID,但以下行包含该UID的数据。

你会怎么做?

这是我到目前为止所提出的。

public static void P2PLogParser(List<FileInfo> fileList)
{
    foreach (FileInfo fi in fileList)
    {
        //Læser alle linier i csv fil
        foreach (var line in File.ReadAllLines(fi.FullName))
        {
            string MeterUID = GetMeterUID(line);
            string MimHashcode = GetMimHashcode(line);
            string FirmwareUploadStatus = GetFirmwareUploadStatus(line);
            string IsKnown = GetIsKnown(line);
            DateTime P2PTimeStamp = GetTimestamp(line);
            if (IsMeterEntry(line) && !meters.ContainsKey(MeterUID))
            {
                string MeterNr = GetMeterUID(line).Replace("4B414D", "");
                int meternr = int.Parse(MeterNr, System.Globalization.NumberStyles.HexNumber);
                meters.Add(MeterUID, new Meter()
                {
                    MeterUID = MeterUID,
                    MeterNR = meternr,
                    P2Pmeterentry = new List<P2PMeterEntry>()
                });
            }
            if (IsMeterEntry(line))
            {
                P2PMeterEntry p2pmeter = new P2PMeterEntry
                {
                    P2PTimeStamp = P2PTimeStamp,
                    MimHashcode = MimHashcode,
                    FirmwareUploadStatus = FirmwareUploadStatus,
                    IsKnown = IsKnown,
                    P2PMetersession = new List<P2PMeterSession>()
                };
                if (IsNoLongerMeterEntry(line))
                {
                    string SessionLevel = GetLevel(line);
                    string SessionMessage = GetSessionMessage(line);
                    string Context = GetSessionContext(line);
                    P2PMeterSession MeterSession = new P2PMeterSession
                    {
                        SessionTimeStamp = P2PTimeStamp,
                        SessionLevel = SessionLevel,
                        SessionMessage = SessionMessage,
                        Context = Context

                    };
                    meterSession.Add(MeterSession);
                }
                meters[MeterUID].P2Pmeterentry.Add(p2pmeter);
            }
        }
    }
}

以及IsMeterEntry和IsNoLongerMeterEntry

//IsMeterSession
public static bool IsMeterEntry(string text)
{
    return text.ToLower().Contains("announce message received:");
}

public static bool IsNoLongerMeterEntry(string text)
{
    return text.ToLower().Contains("context - disposed");
}

1 个答案:

答案 0 :(得分:1)

实现一个具有两种状态的简单状态机:IgnoreLine(初始状态)和Announce。

for each line in log
   if line contains "Announce message"
     read UID
     create a StringBuilder
     set state=Announce
   else if line contains "Disposed"
     store the StringBuilder's content in the dictionary[uid]
     set state=IgnoreLine
   else if state==Announce and line contains "certain words"
     append line to StringBuilder
相关问题