记-Golang日志文件读取及写入操作
Golang语言的 os 包中OpenFile 函数,如下所示:
func OpenFile(name string, flag int, perm FileMode) (*File, error) {
}
其中 name 是文件的文件名,如果不是在当前路径下运行需要加上具体路径;flag 是文件的处理参数,为 int 类型,根据系统的不同具体值可能有所不同,但是作用是相同的。
- O_RDONLY:只读模式打开文件;
- O_WRONLY:只写模式打开文件;
- O_RDWR:读写模式打开文件;
- O_APPEND:写操作时将数据附加到文件尾部(追加);
- O_CREATE:如果不存在将创建一个新文件;
- O_EXCL:和 O_CREATE 配合使用,文件必须不存在,否则返回一个错误;
- O_SYNC:当进行一系列写操作时,每次都要等待上次的 I/O 操作完成再进行;
- O_TRUNC:如果可能,在打开时清空文件。
【实例】该段代码为博主测试用于模拟输出日志。
package main
import (
"bufio"
"fmt"
"io"
"os"
"strings"
"sync"
"time"
)
func main() {
var list []string
mx := sync.Mutex{}
LogFileReading(&list,&mx)
for _, v := range list {
if strings.Contains(v,"/coco-server/v2/user-getGroupList") || strings.Contains(v,"/coco-server/v2/userSession/isPCOnline") ||
strings.Contains(v,"/coco-server/msg-synOffLineMsg") || strings.Contains(v,"/coco-server/msg-updateMsgIndex") {
time.Sleep(1 * time.Second) //设置日志输出
LogFileWrite(v)
}
}
}
func LogFileReading(list *[]string,mutex *sync.Mutex) {
filePath := "目录"
inputFile, inputError := os.OpenFile(filePath,os.O_RDONLY,0)
if inputError != nil {
fmt.Sprintf("An error occurred on opening the inputfile\n" +
"Does the file exist?\n ")
return
}
//及时关闭file
defer inputFile.Close()
//读取文件时,使用带缓存的 *Reader
inputReading := bufio.NewReader(inputFile)
for {
//ReadString将文件内容真正的读取出来
inputString, readerError := inputReading.ReadString('\n')
if readerError == io.EOF {
return
}
mutex.Lock()
*list = append(*list, inputString)
mutex.Unlock()
}
}
func LogFileWrite(v string) {
filePath := "目录"
file, err := os.OpenFile(filePath, os.O_WRONLY|os.O_APPEND|os.O_CREATE, 0666)
if err != nil {
fmt.Println("File open failed!", err)
}
//及时关闭file
defer file.Close()
//写入文件时,使用带缓存的 *Writer
write := bufio.NewWriter(file)
write.WriteString(v)
//Flush将缓存的文件真正写入到文件中
write.Flush()
}
转载请声明出处哦~,本篇文章发布于Biuget-Golang的博客:
https://www.cnblogs.com/Biuget-Golang/

浙公网安备 33010602011771号