C#开发日志工具类

namespace Log.Utils
{
    public class TextLogUtil
    {
        private static readonly object locker = new object();
        private static StreamWriter sw;
        private static Timer changePathTimer;
        private static readonly int CHANGEPATHINTERVAL = 60 * 1000;
        private static readonly string LOGFILENAMEFORMAT = "yyyyMMdd_HH";
        private static readonly string LOGLINEFORMAT = "HH:mm:ss_ffff";
        private static LogLevel logLevel;

        static TextLogUtil()
        {
            changePathTimer = new Timer(state =>
            {
                lock (locker)
                {
                    Close();
                    InitStreamWriter();
                }
            }, null, CHANGEPATHINTERVAL, CHANGEPATHINTERVAL);
            InitStreamWriter();
        }

        #region internal
        internal static void Close()
        {
            try
            {
                if (sw != null)
                    sw.Close();
            }
            catch
            {
            }
        }
        #endregion

        #region private

        private static void InitStreamWriter()
        {
            logLevel = LogLevel.Debug;
            try
            {
                sw = new StreamWriter(GetLogFileName(), true, Encoding.UTF8, 1024);
                sw.AutoFlush = 
  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
为了简化C#文件备份工具的开发,可以使用Visual Studio和一些第三方库。以下是一些步骤: 1. 创建一个新的C#控制台应用程序项目。 2. 使用System.IO命名空间中的类来处理文件和文件夹。例如,使用File类的Copy方法来复制文件,使用Directory类的CreateDirectory方法来创建目录。 3. 使用命令行参数来指定源文件夹和目标文件夹。可以使用args数组来访问这些参数。 4. 使用第三方库来简化开发。例如,可以使用CommandLineParser库来处理命令行参数,使用NLog库来记录日志,使用Newtonsoft.Json库来处理JSON数据。 5. 使用try-catch块来处理异常,以确保程序在出现错误时不会崩溃。 以下是一个简单的C#文件备份工具的示例代码: ```csharp using System; using System.IO; using CommandLine; using NLog; namespace FileBackupTool { class Program { static void Main(string[] args) { var logger = LogManager.GetCurrentClassLogger(); Parser.Default.ParseArguments<Options>(args) .WithParsed<Options>(options => { try { logger.Info("Starting file backup..."); // Copy files from source directory to target directory foreach (string file in Directory.GetFiles(options.SourceDirectory)) { string fileName = Path.GetFileName(file); string targetFile = Path.Combine(options.TargetDirectory, fileName); File.Copy(file, targetFile, true); logger.Info("Copied file {0} to {1}", file, targetFile); } // Copy directories from source directory to target directory foreach (string dir in Directory.GetDirectories(options.SourceDirectory)) { string dirName = Path.GetFileName(dir); string targetDir = Path.Combine(options.TargetDirectory, dirName); Directory.CreateDirectory(targetDir); CopyDirectory(dir, targetDir); logger.Info("Copied directory {0} to {1}", dir, targetDir); } logger.Info("File backup completed successfully."); } catch (Exception ex) { logger.Error(ex, "An error occurred while backing up files."); } }); } static void CopyDirectory(string sourceDir, string targetDir) { foreach (string file in Directory.GetFiles(sourceDir)) { string fileName = Path.GetFileName(file); string targetFile = Path.Combine(targetDir, fileName); File.Copy(file, targetFile, true); } foreach (string dir in Directory.GetDirectories(sourceDir)) { string dirName = Path.GetFileName(dir); string targetSubDir = Path.Combine(targetDir, dirName); Directory.CreateDirectory(targetSubDir); CopyDirectory(dir, targetSubDir); } } } class Options { [Option('s', "source", Required = true, HelpText = "Source directory")] public string SourceDirectory { get; set; } [Option('t', "target", Required = true, HelpText = "Target directory")] public string TargetDirectory { get; set; } } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值