如何格式化File.WriteTextAll函数的输出?

时间:2015-01-05 16:36:47

标签: c# sql winforms

对于这个项目,我正在接受SQL数据库的输入并将其放入一个txt文件中以便于传输,什么不能。

到目前为止它有效,但我想让它更容易阅读。当这个应用程序运行时,它每60秒更新一次文件。我想在列中添加标题,以便有人阅读它可以告诉每列代表什么。 我不知道如何添加标题,以便在标题下方的每个刷新插入中添加新文本。

这是我到目前为止所拥有的

private void Output()
        {
            string createText = "";


            foreach (KeyValuePair<string, AlarmData> AlarmDataText in AlarmDictionary)
            {
                createText += FormatWidth(AlarmDataText.Value.eventSeverity, 8) + FormatWidth(AlarmDataText.Value.eventLastNotification.ToString("yyyy-MM-dd HH:mm"), 18) +
                FormatWidth(AlarmDataText.Value.eventFirstNotification.ToString("yyyy-MM-dd HH:mm"), 18) + FormatWidth(AlarmDataText.Value.deviceIP, 18) + 
                FormatWidth(AlarmDataText.Value.deviceInterface, 20) + AlarmDataText.Value.descriptionShort;
                createText += Environment.NewLine;
            }

            if (true)
            {

            }
            File.WriteAllText("C:\\Users\\%username%\\Documents\\Visual Studio 2010\\Projects\\NMS_Logger\\NMS_Logger\\bin\\Log.txt", createText);

        }//end Output()

这是一个如何在文本文件中出现的样本

Major   2015-01-05 11:15  2014-11-11 09:55  10.10.10.1               apSysMgmtInet
Major   2015-01-05 11:15  2014-11-11 09:56  10.10.10.1               apSysMgmtInet
Major   2015-01-05 11:16  2014-11-13 12:35  10.10.10.1    bwCNAMS    C N A M Server 
Info    2015-01-05 11:17  2015-01-02 03:29  10.10.10.1               CIT Debug Trap 
Major   2015-01-05 11:15  2014-11-14 09:48  10.10.10.1    RAI        telicaT1Alarm 
Major   2015-01-05 11:17  2014-11-20 02:11  10.10.10.1               portErrorsExceeded 
Info    2015-01-05 11:15  2015-01-05 11:14  10.10.10.1    NORMAL     telicaT1Event 
Major   2015-01-05 11:15  2014-11-14 09:48  10.10.10.1    RAI        telicaT1Alarm 
Info    2015-01-05 11:15  2015-01-05 11:14  10.10.10.1    NORMAL     telicaT1Event 
Major   2015-01-05 11:17  2014-11-12 05:05  10.10.10.1               Error ENVMON
Info    2015-01-05 11:16  2014-12-03 15:43  10.10.10.1               Debug SEC

正如您所见,列标签会很好。

2 个答案:

答案 0 :(得分:2)

您可以在createText上添加您的列名称,如下所示:

string createText = //just make sure that the column name doesn't exceed your padding width
        FormatWidth("Severity" 8) + 
        FormatWidth("LastNotification") +
        FormatWidth("FirstNotification", 18) + 
        FormatWidth("DeviceIP", 18) + 
        FormatWidth("DeviceInterface", 20) + 
        "DescriptionShort";

foreach (KeyValuePair<string, AlarmData> AlarmDataText in AlarmDictionary)
{
    createText += Environment.NewLine;
    createText += 
        FormatWidth(AlarmDataText.Value.eventSeverity, 8) + 
        FormatWidth(AlarmDataText.Value.eventLastNotification.ToString("yyyy-MM-dd HH:mm"), 18) +
        FormatWidth(AlarmDataText.Value.eventFirstNotification.ToString("yyyy-MM-dd HH:mm"), 18) + 
        FormatWidth(AlarmDataText.Value.deviceIP, 18) + 
        FormatWidth(AlarmDataText.Value.deviceInterface, 20) + 
        AlarmDataText.Value.descriptionShort;
}

答案 1 :(得分:0)

在foreach循环之外和语句string createText = "";之后,您可以将合适的列名追加到createText。而不是使用String尝试使用StringBuilder