• golang写日志函数


    
    package common
    
    import (
    	"bufio"
    	"fmt"
    	"os"
    	"time"
    )
    
    
    /*自定义日志文件*/
    func DebugLog(args ...interface{}) error {
    	var floderLog = "logs"
    	logName := floderLog + "/debug_log." + time.Now().Format("2006-01-02") + ".log"
    	if _, err := os.Stat(floderLog); err != nil {
    		if !os.IsExist(err) {
    			os.MkdirAll(floderLog, os.ModePerm)
    		}
    	}
    
    	logFile, err := os.OpenFile(logName, os.O_APPEND|os.O_RDWR|os.O_CREATE, os.ModePerm)
    	if err != nil {
    		fmt.Print("打开文件失败")
    		return err
    	}
    	defer logFile.Close()
    	tm := time.Now().Format("2006-01-02 15:04:05")
    	logBody := fmt.Sprintf("%s star============================================>
    ", tm)
    	logFile.WriteString(logBody)
    	logBody = fmt.Sprintf("%+v
    ", args)
    	logFile.WriteString(logBody)
    	logBody = fmt.Sprintf("
    ")
    	logFile.WriteString(logBody)
    	return nil
    }
    
    //DebugLog2 自定义日志文件
    /*
    * dir 文件夹名字
    * fileName 文件名字
    * args 要写入的数据
     */
    func Log(dir string, fileName string, args ...interface{}) error {
    	var floderLog = "logs"
    	if fileName != "" {
    		floderLog = floderLog + "/" + dir
    	}
    	logName := floderLog + "/" + fileName + time.Now().Format("2006-01-02") + ".log"
    	if _, err := os.Stat(floderLog); err != nil {
    		if !os.IsExist(err) {
    			os.MkdirAll(floderLog, os.ModePerm)
    		}
    	}
    
    	logFile, err := os.OpenFile(logName, os.O_APPEND|os.O_RDWR|os.O_CREATE, os.ModePerm)
    	if err != nil {
    		fmt.Println("打开文件失败 err:", err)
    		return err
    	}
    	defer logFile.Close()
    	tm := time.Now().Format("2006-01-02 15:04:05")
    
    	//方法一:os包
    	// logBody := fmt.Sprintf("%s star============================================>
    ", tm)
    	// logFile.WriteString(logBody)
    	// logBody = fmt.Sprintf("%+v
    ", args)
    	// logFile.WriteString(logBody)
    	// logBody = fmt.Sprintf("
    ")
    	// logFile.WriteString(logBody)
    
    	//方法二:bufio包
    	writer := bufio.NewWriter(logFile)
    	logBody := fmt.Sprintf("%s star============================================>
    ", tm)
    	writer.WriteString(logBody) //写入缓存
    	logBody = fmt.Sprintf("%+v
    ", args)
    	writer.WriteString(logBody)
    	logBody = fmt.Sprintf("
    ")
    	writer.WriteString(logBody)
    
    	writer.Flush() //从缓存写入文件
    	return nil
    }
    
    
  • 相关阅读:
    利用树莓派把普通打印机变成网络打印机方法
    Python之datetime库
    CentOS7从默认/home中转移空间到根分区/
    更改Azure虚拟机账号密码
    创建一个托管磁盘的Windows定制镜像
    IO多路复用详解
    玩转redis
    EF Linq to Sql 多表left join查询并对结果group by分组之后进行count,max等处理
    免费,主流的在线办公/协作,会议,文档,调查,分享工具推荐(持续维护中)
    多sql查询count合并为一行
  • 原文地址:https://www.cnblogs.com/haima/p/14004745.html
Copyright © 2020-2023  润新知