Golang秒懂----写log日志文件

先代码,后说明:
package main

import (
	"log"
	"os"
)

var logger *log.Logger

func main() {
	logger.Println("I write a test log")
}

func init() {
	//指定路径的文件,无则创建
	logFile, err := os.OpenFile("./log.log", os.O_RDWR|os.O_CREATE|os.O_APPEND, 0666)
	if err != nil {
		panic(err)
	}
	logger = log.New(logFile, "[test]", log.Ltime)
}
  • os.OpenFile
    • 功能:打开文件
    • 函数原型:func OpenFile(name string, flag int, perm FileMode) (file *File, err error)
    • 返回值:
      成功,返回的文件对象
      失败,err错误底层类型是*PathError
    • 参数解释:
      name:文件路径及文件名
      flag:文件操作类型码
      perm:文件模式
二参码值释义
O_RDONLY只读模式打开文件
O_RDONLY只读模式打开文件
O_WRONLY只写模式打开文件
O_RDWR读写模式打开文件
O_APPEND写操作时将数据附加到文件尾部
O_CREATE如果不存在将创建一个新文件
O_EXCL和O_CREATE配合使用,文件必须不存在
O_SYNC打开文件用于同步I/O
O_TRUNC如果可能,打开时清空文件
flag 码值释义
0666任何人都可读写,不可执行
0777覆盖所有Unix权限位(用于通过&获取类型位)
  • log.New
    • 功能:创建一个Logger对象
    • 函数原型:func New(out io.Writer, prefix string, flag int) *Logger
    • 返回值:
      成功,返回的文件对象
      失败,err错误底层类型是*PathError
    • 参数解释:
      out:写入文件的对象
      prefix:添加到每一条日志前面的字符串
      flag:日志的属性
flag码值释义
Ldate日期:2009/01/23
Ltime时间:01:23:23
Lmicroseconds微秒分辨率:01:23:23.123123(用于增强Ltime位)
Llongfile文件全路径名+行号: /a/b/c/d.go:23
Lshortfile文件无路径名+行号:d.go:23(会覆盖掉Llongfile)
LstdFlags标准logger的初始值
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值