go 文件操作 io

package main
import (
    "fmt"
    "os" 
)
func main() {
    //打开文件
    //概念说明: file 的叫法
    //1. file 叫 file对象
    //2. file 叫 file指针
    //3. file 叫 file 文件句柄
    file , err := os.Open("d:/test.txt")
    if err != nil {
        fmt.Println("open file err=", err)
    }
    //输出下文件,看看文件是什么, 看出file 就是一个指针 *File
    fmt.Printf("file=%v", file)
    //关闭文件
    err = file.Close()
    if err != nil {
        fmt.Println("close file err=", err)
    }
}

package main
import (
    "fmt"
    "os"
    "bufio"
    "io" 
)
func main() {
    //打开文件
    //概念说明: file 的叫法
    //1. file 叫 file对象
    //2. file 叫 file指针
    //3. file 叫 file 文件句柄
    file , err := os.Open("d:/test.txt")
    if err != nil {
        fmt.Println("open file err=", err)
    }

    //当函数退出时,要及时的关闭file
    defer file.Close() //要及时关闭file句柄,否则会有内存泄漏.

    // 创建一个 *Reader  ,是带缓冲的
    /*
    const (
    defaultBufSize = 4096 //默认的缓冲区为4096
    )
    */
    reader := bufio.NewReader(file)
    //循环的读取文件的内容
    for {
        str, err := reader.ReadString('
') // 读到一个换行就结束
        if err == io.EOF { // io.EOF表示文件的末尾
            break
        }
        //输出内容
        fmt.Printf(str)
    }

    fmt.Println("文件读取结束...")
}

package main
import (
	"fmt"
	"io/ioutil" 
)
func main() {

	//使用ioutil.ReadFile一次性将文件读取到位
	file := "d:/test.txt"
	content, err := ioutil.ReadFile(file)
	if err != nil {
		fmt.Printf("read file err=%v", err)
	}
	//把读取到的内容显示到终端
	//fmt.Printf("%v", content) // []byte
	fmt.Printf("%v", string(content)) // []byte
	
	//我们没有显式的Open文件,因此也不需要显式的Close文件
	//因为,文件的Open和Close被封装到 ReadFile 函数内部
}

  

package main
import (
	"fmt"
	"bufio"
	"os" 
)
func main() {
	//创建一个新文件,写入内容 5句 "hello, Gardon"
	//1 .打开文件 d:/abc.txt
	filePath := "d:/abc.txt"
	file, err := os.OpenFile(filePath, os.O_WRONLY | os.O_CREATE, 0666)
	if err != nil {
		fmt.Printf("open file err=%v
", err)
		return 
	}
	//及时关闭file句柄
	defer file.Close()
	//准备写入5句 "hello, Gardon"
	str := "hello,Gardon
" // 
 表示换行
	//写入时,使用带缓存的 *Writer
	writer := bufio.NewWriter(file)
	for i := 0; i < 5; i++ {
		writer.WriteString(str)
	}
	//因为writer是带缓存,因此在调用WriterString方法时,其实
	//内容是先写入到缓存的,所以需要调用Flush方法,将缓冲的数据
	//真正写入到文件中, 否则文件中会没有数据!!!
	writer.Flush()
}

  

file, err := os.OpenFile(filePath, os.O_WRONLY | os.O_TRUNC, 0666)
package main
import (
    "fmt"
    "bufio"
    "os" 
)

func main() {
    //打开一个存在的文件中,将原来的内容覆盖成新的内容10句 "你好,尚硅谷!"

    //创建一个新文件,写入内容 5句 "hello, Gardon"
    //1 .打开文件已经存在文件, d:/abc.txt
    filePath := "d:/abc.txt"
    file, err := os.OpenFile(filePath, os.O_WRONLY | os.O_TRUNC, 0666)
    if err != nil {
        fmt.Printf("open file err=%v
", err)
        return 
    }
    //及时关闭file句柄
    defer file.Close()
    //准备写入5句 "你好,尚硅谷!"
    str := "你好,尚硅谷!
" // 
 表示换行
    //写入时,使用带缓存的 *Writer
    writer := bufio.NewWriter(file)
    for i := 0; i < 10; i++ {
        writer.WriteString(str)
    }
    //因为writer是带缓存,因此在调用WriterString方法时,其实
    //内容是先写入到缓存的,所以需要调用Flush方法,将缓冲的数据
    //真正写入到文件中, 否则文件中会没有数据!!!
    writer.Flush()

}

 

file, err := os.OpenFile(filePath, os.O_WRONLY | os.O_APPEND, 0666)
package main
import (
    "fmt"
    "bufio"
    "os" 
)

func main() {
    

    //打开一个存在的文件,在原来的内容追加内容 'ABC! ENGLISH!'
    //1 .打开文件已经存在文件, d:/abc.txt
    filePath := "d:/abc.txt"
    file, err := os.OpenFile(filePath, os.O_WRONLY | os.O_APPEND, 0666)
    if err != nil {
        fmt.Printf("open file err=%v
", err)
        return 
    }
    //及时关闭file句柄
    defer file.Close()
    //准备写入5句 "你好,尚硅谷!"
    str := "ABC,ENGLISH!
" // 
 表示换行
    //写入时,使用带缓存的 *Writer
    writer := bufio.NewWriter(file)
    for i := 0; i < 10; i++ {
        writer.WriteString(str)
    }
    //因为writer是带缓存,因此在调用WriterString方法时,其实
    //内容是先写入到缓存的,所以需要调用Flush方法,将缓冲的数据
    //真正写入到文件中, 否则文件中会没有数据!!!
    writer.Flush()

}

package main
import (
    "fmt"
    "bufio"
    "os"
    "io" 
)

func main() {
    
    //打开一个存在的文件,将原来的内容读出显示在终端,并且追加5句"hello,北京!"
    //1 .打开文件已经存在文件, d:/abc.txt
    filePath := "d:/abc.txt"
    file, err := os.OpenFile(filePath, os.O_RDWR | os.O_APPEND, 0666)
    if err != nil {
        fmt.Printf("open file err=%v
", err)
        return 
    }
    //及时关闭file句柄
    defer file.Close()

    //先读取原来文件的内容,并显示在终端.
    reader := bufio.NewReader(file)
    for {
        str, err := reader.ReadString('
')
        if err == io.EOF { //如果读取到文件的末尾
            break
        }
        //显示到终端
        fmt.Print(str)
    }


    //准备写入5句 "你好,尚硅谷!"
    str := "hello,北京!
" // 
 表示换行
    //写入时,使用带缓存的 *Writer
    writer := bufio.NewWriter(file)
    for i := 0; i < 5; i++ {
        writer.WriteString(str)
    }
    //因为writer是带缓存,因此在调用WriterString方法时,其实
    //内容是先写入到缓存的,所以需要调用Flush方法,将缓冲的数据
    //真正写入到文件中, 否则文件中会没有数据!!!
    writer.Flush()

}

package main
import (
    "fmt"
    "io/ioutil" 
)
func main() {
    //将d:/abc.txt 文件内容导入到  e:/kkk.txt
    //1. 首先将  d:/abc.txt 内容读取到内存
    //2. 将读取到的内容写入 e:/kkk.txt
    file1Path := "d:/abc.txt" 
    file2Path := "e:/kkk.txt" 
    data, err := ioutil.ReadFile(file1Path)
    if err != nil {
        //说明读取文件有错误
        fmt.Printf("read file err=%v
", err)
        return
    }
    err = ioutil.WriteFile(file2Path, data, 0666)
    if err != nil {
        fmt.Printf("write file error=%v
", err)
    }
}

package main
import (
    "fmt"
    "os"
    "io"
    "bufio" 
)

//自己编写一个函数,接收两个文件路径 srcFileName dstFileName
func CopyFile(dstFileName string, srcFileName string) (written int64, err error) {

    srcFile, err := os.Open(srcFileName)
    if err != nil {
        fmt.Printf("open file err=%v
", err)
    }
    defer srcFile.Close()
    //通过srcfile ,获取到 Reader
    reader := bufio.NewReader(srcFile)

    //打开dstFileName
    dstFile, err := os.OpenFile(dstFileName, os.O_WRONLY | os.O_CREATE, 0666)
    if err != nil {
        fmt.Printf("open file err=%v
", err)
        return 
    }

    //通过dstFile, 获取到 Writer
    writer := bufio.NewWriter(dstFile)
    defer dstFile.Close()

    return io.Copy(writer, reader)


}

func main() {

    //将d:/flower.jpg 文件拷贝到 e:/abc.jpg

    //调用CopyFile 完成文件拷贝
    srcFile := "d:/flower.jpg"
    dstFile := "e:/abc.jpg"
    _, err := CopyFile(dstFile, srcFile)
    if err == nil {
        fmt.Printf("拷贝完成
")
    } else {
        fmt.Printf("拷贝错误 err=%v
", err)
    }
    
}

package main
import (
    "fmt"
    "os"
    "io"
    "bufio" 
)

//定义一个结构体,用于保存统计结果
type CharCount struct {
    ChCount int // 记录英文个数
    NumCount int // 记录数字的个数
    SpaceCount int // 记录空格的个数
    OtherCount int // 记录其它字符的个数
}

func main() {

    //思路: 打开一个文件, 创一个Reader
    //每读取一行,就去统计该行有多少个 英文、数字、空格和其他字符
    //然后将结果保存到一个结构体
    fileName := "e:/abc.txt"
    file, err := os.Open(fileName)
    if err != nil {
        fmt.Printf("open file err=%v
", err)
        return
    }
    defer file.Close()
    //定义个CharCount 实例
    var count CharCount
    //创建一个Reader
    reader := bufio.NewReader(file)

    //开始循环的读取fileName的内容
    for {
        str, err := reader.ReadString('
')
        if err == io.EOF { //读到文件末尾就退出
            break
        }
        //遍历 str ,进行统计
        for _, v := range str {
            
            switch {
                case v >= 'a' && v <= 'z':
                        fallthrough //穿透
                case v >= 'A' && v <= 'Z':
                        count.ChCount++
                case v == ' ' || v == '	':
                        count.SpaceCount++
                case v >= '0' && v <= '9':
                        count.NumCount++
                default :
                        count.OtherCount++
            }
        }
    }

    //输出统计的结果看看是否正确
    fmt.Printf("字符的个数为=%v 数字的个数为=%v 空格的个数为=%v 其它字符个数=%v", 
        count.ChCount, count.NumCount, count.SpaceCount, count.OtherCount)


}

package main

import (
    "bytes"
    "os"
)

func main(){
    var myname bytes.Buffer
    myname.Write([]byte("sunlong"))
    myname.WriteTo(os.Stdout)
}


...
sunlong
Process finished with exit code 0
...

缓冲区,只有当内存达到一定数量后才会写入

原文地址:https://www.cnblogs.com/sunlong88/p/11183762.html