記-Golang日誌檔案讀取及寫入操作
阿新 • • 發佈:2022-04-06
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/