评论

收藏

[C++] C# 简单日志文本输出

编程语言 编程语言 发布于:2021-07-21 17:41 | 阅读数:486 | 评论:0

C# 简单日志文本输出
第一种  直接文件IO流写日志文件
using System.IO;
public static void WriteLog(string strLog)
{
  string sFilePath="d:\"+DateTime.Now.ToString("yyyyMM");
  string sFileName = "rizhi" + DateTime.Now.ToString("dd") + ".log";
  sFileName = sFilePath+ "\"+sFileName; //文件的绝对路径
  if (!Directory.Exists(sFilePath))//验证路径是否存在
  {
  Directory.CreateDirectory(sFilePath);
  //不存在则创建
  }
  FileStream fs;    
  StreamWriter sw;
  if (File.Exists(sFileName))
  //验证文件是否存在,有则追加,无则创建
  {
  fs = new FileStream(sFileName, FileMode.Append, FileAccess.Write);
  }
  else
  {
  fs = new FileStream(sFileName, FileMode.Create, FileAccess.Write);
  }
  sw = new StreamWriter(fs);
  sw.WriteLine(DateTime.Now.ToString("yyyy-MM-dd HH-mm-ss") + "   ---   " + strLog);
  sw.Close();
  fs.Close();  
}
第二种 使用log4net类库输出日志
1.下载log4net类库 并选择项目对应的框架版本
下载地址:http://logging.apache.org/log4net/download_log4net.cgi
2.添加log4net引用,创建LogHelper类。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using log4net;
using log4net.Core;
[assembly: log4net.Config.XmlConfigurator(Watch = true)]
namespace BoilerDashboard.Common
{
  public  class LogHelper
  {
    /// <summary>
    /// 输出日志到Log4Net
    /// </summary>
    /// <param name="t"></param>
    /// <param name="ex"></param>
    #region static void WriteLog(Type t, Exception ex)
    public static void WriteLog(Type t, Exception ex)
    {
      log4net.ILog log = log4net.LogManager.GetLogger(t);
      log.Error("Error", ex);
    }
    #endregion
    /// <summary>
    /// 输出日志到Log4Net
    /// </summary>
    /// <param name="t"></param>
    /// <param name="msg"></param>
    #region static void WriteLog(Type t, string msg)
    public static void WriteLog(Type t, string msg)
    {
      log4net.ILog log = log4net.LogManager.GetLogger(t);
      log.Error(msg);
    }
    #endregion

    
  }
}
第三种 Microsoft Enterprise Library里面的Log功能
以VS2012里面建立的一个控制台程序为例1. 安装Microsoft Enterprise Library里面的Logging Application模块。在需要使用Log功能的项目上面右键,选择Manage NuGet Packeages...2. 在Manage NuGet Packeages窗口里面找到Enterprise Library - Logging Application Block,然后安装安装成功以后,项目引用中会增加两个新的引用。3. 我们需要对App.config文件进行配置。在这里我们使用配置编辑工具:Microsoft.Practices.EnterpriseLibrary.ConfigConsoleV6.vsix。这个工具的下载地址:http://www.microsoft.com/en-us/download/details.aspx?id=387894. 配置App.config文件。右键App.config文件选择Edit configuration file v6,打开配置工具窗口。5. 选择菜单命令Block -> Add Logging Settings6. 在Logging Target Listeners里面点加号按钮,然后选择Add Rolling Flat File Trace Listener(生成可以进行自动分割的文本文件)。7. 一般需要设置的参数有:Asynchronous(选true则进行异步log), File Exist Behavior(选), File Name, Formatter Name, Max Archived Files, Roll Interval, Roll Size KB。其中Formatter Name的值从Log Message Formatters中生成的值中选取。8. 生成 Message Format。在Log Message Formatters中点击加号按钮,选择Add Text Formatter点击Template右侧的...按钮,打开Template Editor对话框,对Template的内容进行编辑编辑后在App.config中生成的xml代码如下:Logging formatter9. 在窗口左侧区域中点击Cotegories右边的加号按钮。生成一个新的Category10. 在新生成的Category区域中修改Name属性,然后点击Listeners右边的加号按钮,选择在Logging Target Listeners区域中已经生成的Listener。11. 对已经进行的设置保12. 写个简单的测试程序看看生成的Log效果如何

关注下面的标签,发现更多相似文章