Log.cs 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. //############################################################
  2. // https://github.com/yuzhengyang
  3. // author:yuzhengyang
  4. //############################################################
  5. using System;
  6. using System.Runtime.InteropServices;
  7. using Y.Utils.IOUtils.PathUtils;
  8. using Y.Utils.IOUtils.TxtUtils;
  9. namespace Y.Utils.IOUtils.LogUtils
  10. {
  11. /// <summary>
  12. /// Log 输出工具
  13. ///
  14. /// 说明:
  15. /// 1、Log.AllocConsole();开启控制台
  16. /// 2、Log.FreeConsole();关闭控制台
  17. /// 3、Log.i("information");输出消息
  18. /// </summary>
  19. public class Log
  20. {
  21. //输出的 Log 格式
  22. const string LogFormat = "{0} {1} {2}";
  23. const string TimeFormat = "HH:mm:ss.fff";
  24. private object LogFileLock = new object();//写日志文件锁
  25. public bool IsWriteFile = true;//是否写日志文件
  26. public LogLevel LogLevel = LogLevel.All;//日志输出等级
  27. #region Console 开启/关闭 API
  28. [DllImport("kernel32.dll")]
  29. public static extern Boolean AllocConsole();
  30. [DllImport("kernel32.dll")]
  31. public static extern Boolean FreeConsole();
  32. #endregion
  33. /// <summary>
  34. /// 获取输出颜色
  35. /// </summary>
  36. /// <param name="type">输出类型</param>
  37. /// <returns></returns>
  38. private static ConsoleColor GetColor(LogType type)
  39. {
  40. switch (type)
  41. {
  42. case LogType.v: return ConsoleColor.Gray;
  43. case LogType.d: return ConsoleColor.Blue;
  44. case LogType.i: return ConsoleColor.Green;
  45. case LogType.w: return ConsoleColor.Yellow;
  46. case LogType.e: return ConsoleColor.Red;
  47. default: return ConsoleColor.Gray;
  48. }
  49. }
  50. /// <summary>
  51. /// 写出到控制台
  52. /// </summary>
  53. /// <param name="type">类型</param>
  54. /// <param name="tag">标记</param>
  55. /// <param name="message">消息</param>
  56. private void Write(LogType type, string message)
  57. {
  58. Console.ForegroundColor = GetColor(type);
  59. Console.WriteLine(LogFormat, DateTime.Now.ToString(TimeFormat), type.ToString(), message);
  60. if (IsWriteFile) WriteFile(type, message);
  61. }
  62. private void WriteFile(LogType type, string message)
  63. {
  64. if (IsWriteFile)
  65. {
  66. lock (LogFileLock)
  67. {
  68. //设置日志目录
  69. string logPath = AppDomain.CurrentDomain.BaseDirectory + "Log";
  70. string file = string.Format(@"{0}\{1}.txt", logPath, DateTime.Now.ToString("yyyy-MM-dd"));
  71. //创建日志目录
  72. DirTool.Create(logPath);
  73. //写出日志
  74. TxtTool.Append(file, string.Format(LogFormat, DateTime.Now.ToString(TimeFormat), type.ToString(), message));
  75. }
  76. }
  77. }
  78. #region 分类详细输出
  79. /// <summary>
  80. /// 输出 verbose (啰嗦信息)
  81. /// </summary>
  82. /// <param name="message">消息</param>
  83. /// <param name="tag">可选:标记</param>
  84. public void v<T>(T msg)
  85. {
  86. if ((LogLevel & LogLevel.Verbose) == LogLevel.Verbose)
  87. Write(LogType.v, msg.ToString());
  88. }
  89. /// <summary>
  90. /// 输出 Debug (调试信息)
  91. /// </summary>
  92. /// <param name="message">消息</param>
  93. /// <param name="tag">可选:标记</param>
  94. public void d<T>(T msg)
  95. {
  96. if ((LogLevel & LogLevel.Debug) == LogLevel.Debug)
  97. Write(LogType.d, msg.ToString());
  98. }
  99. /// <summary>
  100. /// 输出 Information (重要信息)
  101. /// </summary>
  102. /// <param name="message">消息</param>
  103. /// <param name="tag">可选:标记</param>
  104. public void i<T>(T msg)
  105. {
  106. if ((LogLevel & LogLevel.Information) == LogLevel.Information)
  107. Write(LogType.i, msg.ToString());
  108. }
  109. /// <summary>
  110. /// 输出 Warning (警告信息)
  111. /// </summary>
  112. /// <param name="message">消息</param>
  113. /// <param name="tag">可选:标记</param>
  114. public void w<T>(T msg)
  115. {
  116. if ((LogLevel & LogLevel.Warning) == LogLevel.Warning)
  117. Write(LogType.w, msg.ToString());
  118. }
  119. /// <summary>
  120. /// 输出 Error (错误信息)
  121. /// </summary>
  122. /// <param name="message">消息</param>
  123. /// <param name="tag">可选:标记</param>
  124. public void e<T>(T msg)
  125. {
  126. if ((LogLevel & LogLevel.Error) == LogLevel.Error)
  127. Write(LogType.e, msg.ToString());
  128. }
  129. #endregion
  130. }
  131. }