Golang 写日志到文件

Go 复制代码
package main

import (
	"log"
	"os"
	"time"
)

func main() {
	printLog("auto", "报警内容AA")
}

func printLog(filename string, content string) {
	t := time.Now().Format(time.DateOnly)
	file := filename + "." + t + ".log"
    //日志名称为 xx.2024-03-07.log

	f, err := os.OpenFile(file, os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0644)
	if err != nil {
		log.Panic("打开日志文件异常")
	}
	defer f.Close() // 延迟关闭文件句柄
	log.SetOutput(f)
	log.Print(content)
}

OpenFile常用的打开模式:

os.O_RDONLY: 以只读方式打开文件

os.O_WRONLY: 以只写方式打开文件

os.O_RDWR: 以读写方式打开文件

os.O_APPEND: 在文件末尾追加数据

os.O_CREATE: 如果文件不存在则创建新文件

os.O_EXCL: 与O_CREATE一起使用时,要求文件必须是新创建的,如果文件已经存在则返回错误

os.O_SYNC: 打开文件用于同步I/O

os.O_TRUNC: 如果可能,打开文件时先将文件内容清空

相关推荐
eggrall3 分钟前
Linux进程信号——像收快递一样理解 Linux 信号
linux·开发语言·c++
Full Stack Developme11 分钟前
spring-beans 解析
java·后端·spring
foundbug99913 分钟前
MATLAB实现:基于图像对比度和波段相关性的高光谱波段选择算法
开发语言·算法·matlab
czt_java25 分钟前
线程安全问题
java·开发语言·jvm
苏三说技术26 分钟前
为什么大厂都不推荐在MySQL中使用NULL值?
后端
techdashen30 分钟前
Rust 模块和文件不是一回事:一次讲清 `mod`、`use`、`pub use`
开发语言·后端·rust
Wy_编程33 分钟前
go中的协程Goroutine
开发语言·golang
爱勇宝44 分钟前
别焦虑,也别躺平:给年轻程序员的一封信
前端·后端·架构
basketball6161 小时前
C++ 命名空间知识点总结:从入门到合理设计
开发语言·c++
WL_Aurora1 小时前
Java多线程详解(一)
java·开发语言