1. 程式人生 > 其它 >記-Golang日誌檔案讀取及寫入操作

記-Golang日誌檔案讀取及寫入操作

Golang語言的 os 包中OpenFile 函式,如下所示:

func OpenFile(name string, flag int, perm FileMode) (*File, error) {
}

其中 name 是檔案的檔名,如果不是在當前路徑下執行需要加上具體路徑;flag 是檔案的處理引數,為 int 型別,根據系統的不同具體值可能有所不同,但是作用是相同的。

  1. O_RDONLY:只讀模式開啟檔案;
  2. O_WRONLY:只寫模式開啟檔案;
  3. O_RDWR:讀寫模式開啟檔案;
  4. O_APPEND:寫操作時將資料附加到檔案尾部(追加);
  5. O_CREATE:如果不存在將建立一個新檔案;
  6. O_EXCL:和 O_CREATE 配合使用,檔案必須不存在,否則返回一個錯誤;
  7. O_SYNC:當進行一系列寫操作時,每次都要等待上次的 I/O 操作完成再進行;
  8. 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/