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

相关推荐
float_六七8 分钟前
Spring事务注解@Transactional核心机制详解
java·后端·spring
王维志10 分钟前
LiteDB详解
数据库·后端·mongodb·sqlite·c#·json·database
We....17 分钟前
Java分布式编程:RMI机制
java·开发语言·分布式
半凡梦秋21 分钟前
Springboot多线程操作事务
后端
几颗流星24 分钟前
Rust 常用语法速记 - 错误处理
后端·rust
€81125 分钟前
Java入门级教程17——利用Java SPI机制制作验证码、利用Java RMI机制实现分布式登录验证系统
java·开发语言·java spi机制·远程传输数据
lypzcgf26 分钟前
Coze源码分析-资源库-创建知识库-后端源码-应用/领域/数据访问
后端·go·coze·coze源码分析·智能体平台·ai应用平台·agent平台
2301_8153577031 分钟前
parameterType和@Param注解的区别
java·开发语言·数据库
tyatyatya37 分钟前
MATLAB中进行视觉检测入门教程
开发语言·matlab·视觉检测
2401_845417451 小时前
set和map
java·开发语言