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: 如果可能,打开文件时先将文件内容清空

相关推荐
黑仔要睡觉5 分钟前
Anaconda和Pycharm的卸载
开发语言·python
追风少年浪子彦25 分钟前
Spring Boot 使用自定义 JsonDeserializer 同时支持多种日期格式
java·spring boot·后端
bcbnb26 分钟前
Charles抓包在复杂系统中的应用,高难度问题的诊断与验证方法
后端
lqj_本人27 分钟前
Qt与鸿蒙原生桥接实战:网络通信与数据同步问题
开发语言·qt
tan180°31 分钟前
Linux网络IP(下)(16)
linux·网络·后端·tcp/ip
iFlow_AI33 分钟前
iFlow CLI快速搭建Flutter应用记录
开发语言·前端·人工智能·flutter·ai·iflow·iflow cli
非优秀程序员38 分钟前
教程:如何修改 Docker 容器 bisheng-frontend 中的静态文件
后端
我叫黑大帅44 分钟前
六边形架构?小白也能秒懂的「抗造代码秘诀」
java·后端·架构
lly20240644 分钟前
Node.js 创建第一个应用
开发语言
kevinzeng1 小时前
结合Condition实现生产者与消费者示例,来进一步分析AbstractQueuedSynchronizer的内部工作机制
后端