簡體   English   中英

讀取.Log文件中的特定行

[英]Reading specific lines in a .Log file

我有一個日志文件,正在讀取到不同的對象中。 一個對象從包含單詞“ Announce message”的行開始,隨后的行包含屬於該消息的數據。 該條目在包含單詞“ Disposed”的行處停止。 我想從這兩行之間讀取包含某些單詞的所有數據。

我當前使用的是Dictionary,因為帶有“公告消息”的行也包含一個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");
}

實現具有兩個狀態的簡單狀態機: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

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM