golang 读写文件的四种方式

读文件

读取的文件放在file/test:也就是file包下的test这个文件,里面写多一点文件

读文件方式一:利用ioutil.ReadFile直接从文件读取到[]byte中

func Read0()  (string){
    f, err := ioutil.ReadFile("file/test")
    if err != nil {
        fmt.Println("read fail", err)
    }
    return string(f)
}

读文件方式二:先从文件读取到file中,在从file读取到buf, buf在追加到最终的[]byte

func Read1()  (string){
    //获得一个file
    f, err := os.Open("file/test")
    if err != nil {
        fmt.Println("read fail")
        return ""
    }

    //把file读取到缓冲区中
    defer f.Close()
    var chunk []byte
    buf := make([]byte, 1024)

    for {
        //从file读取到buf中
        n, err := f.Read(buf)
        if err != nil && err != io.EOF{
            fmt.Println("read buf fail", err)
            return ""
        }
        //说明读取结束
        if n == 0 {
            break
        }
        //读取到最终的缓冲区中
        chunk = append(chunk, buf[:n]...)
    }

    return string(chunk)
    //fmt.Println(string(chunk))
}

读文件方式三:先从文件读取到file, 在从file读取到Reader中,从Reader读取到buf, buf最终追加到[]byte

//先从文件读取到file, 在从file读取到Reader中,从Reader读取到buf, buf最终追加到[]byte,这个排第三
func Read2() (string) {
    fi, err := os.Open("file/test")
    if err != nil {
        panic(err)
    }
    defer fi.Close()

    r := bufio.NewReader(fi)
    var chunks []byte

    buf := make([]byte, 1024)

    for {
        n, err := r.Read(buf)
        if err != nil && err != io.EOF {
            panic(err)
        }
        if 0 == n {
            break
        }
        //fmt.Println(string(buf))
        chunks = append(chunks, buf...)
    }
    return string(chunks)
    //fmt.Println(string(chunks))
}

读文件方式四:读取到file中,再利用ioutil将file直接读取到[]byte中

//读取到file中,再利用ioutil将file直接读取到[]byte中, 这是最优
func Read3()  (string){
    f, err := os.Open("file/test")
    if err != nil {
        fmt.Println("read file fail", err)
        return ""
    }
    defer f.Close()

    fd, err := ioutil.ReadAll(f)
    if err != nil {
        fmt.Println("read to fd fail", err)
        return ""
    }

    return string(fd)
}

读取速度比较

import (
	"bufio"
	"fmt"
	"io"
	"io/ioutil"
	"os"
	"time"
)

func Read1() string {
	f, err := ioutil.ReadFile("/root/test")
	if err != nil {
		fmt.Println("read fail", err)
	}
	return string(f)
}

func Read2() string {
	//获得一个file
	f, err := os.Open("/root/test")
	if err != nil {
		fmt.Println("read fail")
		return ""
	}

	//把file读取到缓冲区中
	defer f.Close()
	var chunk []byte
	buf := make([]byte, 1024)

	for {
		//从file读取到buf中
		n, err := f.Read(buf)
		if err != nil && err != io.EOF {
			fmt.Println("read buf fail", err)
			return ""
		}
		//说明读取结束
		if n == 0 {
			break
		}
		//读取到最终的缓冲区中
		chunk = append(chunk, buf[:n]...)
	}

	return string(chunk)
	//fmt.Println(string(chunk))
}

func Read3() string {
	fi, err := os.Open("/root/test")
	if err != nil {
		panic(err)
	}
	defer fi.Close()

	r := bufio.NewReader(fi)
	var chunks []byte

	buf := make([]byte, 1024)

	for {
		n, err := r.Read(buf)
		if err != nil && err != io.EOF {
			panic(err)
		}
		if 0 == n {
			break
		}
		//fmt.Println(string(buf))
		chunks = append(chunks, buf...)
	}
	return string(chunks)
	//fmt.Println(string(chunks))
}

func Read4() string {
	f, err := os.Open("/root/test")
	if err != nil {
		fmt.Println("read file fail", err)
		return ""
	}
	defer f.Close()

	fd, err := ioutil.ReadAll(f)
	if err != nil {
		fmt.Println("read to fd fail", err)
		return ""
	}

	return string(fd)
}

func main() {
	start := time.Now().UnixNano() / 1e6
	Read1()
	end := time.Now().UnixNano() / 1e6
	fmt.Printf("Read1=%d,\n", end-start)
}

分别测试 read2 read3 read4

func main() {
	start := time.Now().UnixNano() / 1e6
	Read2()
	end := time.Now().UnixNano() / 1e6
	fmt.Printf("Read2=%d,\n", end-start)
}
func main() {
	start := time.Now().UnixNano() / 1e6
	Read3()
	end := time.Now().UnixNano() / 1e6
	fmt.Printf("Read3=%d,\n", end-start)
}
func main() {
	start := time.Now().UnixNano() / 1e6
	Read4()
	end := time.Now().UnixNano() / 1e6
	fmt.Printf("Read4=%d,\n", end-start)
}

输出结果

[root@localhost src]# ll -h /root | grep test
-rwxr-xr-x. 1 root root 136M Nov  7 19:20 test
[root@localhost src]# go build
[root@localhost src]# ./test
Read1=625,
[root@localhost src]# go build
[root@localhost src]# ./test
Read2=1313,
[root@localhost src]# go build
[root@localhost src]# ./test
Read3=1724,
[root@localhost src]# go build
[root@localhost src]# ./test
Read4=1057,

经过测试,这四种方式读的速度排名是:前者为优
方式一 > 方式四 > 方式二 > 方式三

写文件

写文件方式一:使用 io.WriteString 写入文件

func Write0()  {
    fileName := "file/test1"
    strTest := "测试测试"

    var f *os.File
    var err error

    if CheckFileExist(fileName) {  //文件存在
        f, err = os.OpenFile(fileName, os.O_APPEND, 0666) //打开文件
        if err != nil{
            fmt.Println("file open fail", err)
            return
        }
    }else {  //文件不存在
        f, err = os.Create(fileName) //创建文件
        if err != nil {
            fmt.Println("file create fail")
            return
        }
    }
    //将文件写进去
    n, err1 := io.WriteString(f, strTest)
    if err1 != nil {
        fmt.Println("write error", err1)
        return
    }
    fmt.Println("写入的字节数是:", n)
}

写文件方式二:使用 ioutil.WriteFile 写入文件

func Write1()  {
    fileName := "file/test2"
    strTest := "测试测试"
    var d = []byte(strTest)
    err := ioutil.WriteFile(fileName, d, 0666)
    if err != nil {
        fmt.Println("write fail")
    }
    fmt.Println("write success")
}

写文件方式三:使用 File(Write,WriteString) 写入文件

func Write2()  {

    fileName := "file/test3"
    strTest := "测试测试"
    var d1 = []byte(strTest)

    f, err3 := os.Create(fileName) //创建文件
    if err3 != nil{
        fmt.Println("create file fail")
    }
    defer f.Close()
    n2, err3 := f.Write(d1) //写入文件(字节数组)

    fmt.Printf("写入 %d 个字节n", n2)
    n3, err3 := f.WriteString("writesn") //写入文件(字节数组)
    fmt.Printf("写入 %d 个字节n", n3)
    f.Sync()
}

写文件方式四:使用 bufio.NewWriter 写入文件

func Write3()  {
    fileName := "file/test3"
    f, err3 := os.Create(fileName) //创建文件
    if err3 != nil{
        fmt.Println("create file fail")
    }
    w := bufio.NewWriter(f) //创建新的 Writer 对象
    n4, err3 := w.WriteString("bufferedn")
    fmt.Printf("写入 %d 个字节n", n4)
    w.Flush()
    f.Close()
}

检查文件是否存在

func CheckFileExist(fileName string) bool {
    _, err := os.Stat(fileName)
    if os.IsNotExist(err) {
        return false
    }
    return true
}

  • 7
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Golang中,写入文件有多种方式可以选择。根据引用中的标准包os的type File部分提供的方法和函数,我们可以使用以下函数来写入文件: 1. 使用File的Write方法可以将字节数据写入文件。 ```go func (f *File) Write(b []byte) (n int, err error) ``` 2. 使用File的WriteString方法可以将字符串写入文件。 ```go func (f *File) WriteString(s string) (ret int, err error) ``` 3. 使用OpenFile函数可以打开文件并指定文件的打开模式,然后使用Write方法将数据写入文件。 ```go func OpenFile(name string, flag int, perm FileMode) (file *File, err error) ``` 以上是使用标准包os来进行文件写入的方法。另外,根据引用中的WriteFile函数的实现,我们也可以使用该函数来写入文件。 ```go func WriteFile(filename string, data []byte, perm os.FileMode) error ``` 此外,根据引用中的示例代码,我们还可以使用io.WriteString函数将字符串写入文件。 ```go func io.WriteString(w io.Writer, s string) (n int, err error) ``` 以上是一些常用的Golang写入文件的方法和函数。你可以根据具体需求选择合适的方法来写入文件。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [Golang文件写入的四种方式](https://blog.csdn.net/weixin_37717557/article/details/106532544)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *3* [golang 读写文件四种方式](https://blog.csdn.net/whatday/article/details/103938124)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值