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/