Log.cs 5.0 KB

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