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

相关推荐
小肥宅仙女4 分钟前
限流方案
前端·后端
SadSunset5 分钟前
关于springAOP的总结
java·后端·spring
计算机学姐10 分钟前
基于SpringBoot的演出购票系统【2026最新】
java·vue.js·spring boot·后端·spring·tomcat·intellij-idea
用户68026590511914 分钟前
2025年十大终端管理软件推荐指南
vue.js·后端·面试
ServBay24 分钟前
.NET 10 与 C# 14 更新速览,代码更少,性能更好
后端·c#·.net
心在飞扬29 分钟前
langchain学习总结-Model组件及使用技巧
后端
心在飞扬30 分钟前
langchain学习总结-OutputParser组件及使用技巧
前端·后端
Penge66634 分钟前
ClickHouse 向量化执行:为什么能让查询快几十倍?
后端
心在飞扬35 分钟前
langchain学习总结-两个Runnable核心类的讲解与使用
前端·后端
CDwenhuohuo38 分钟前
uniapp去掉手机状态栏 全屏展示
开发语言·javascript·uni-app