go语言文件操作的常用方法

  • func Open打开文件
 func Open(name string) (file *File, err error)

Open打开一个文件用于读取。如果操作成功,返回的文件对象的方法可用于读取数据;对应的文件描述符具有O_RDONLY模式。如果出错,错误底层类型是*PathError。

  • func (*File) Close关闭文件
func (f *File) Close() error

Close关闭文件f,使文件不能用于读写。它返回可能出现的错误。

 file, err := os.Open("d:/ni.txt")
 if err != nil {
     fmt.Println("open file err=", err)
 }
 fmt.Printf("file=%v", file) //输出file=&{0xc0000a06c8}说明file是一个指针类型
 //关闭文件
 err = file.Close()
 if err != nil {
     fmt.Println("close file err=", err)
 }
  • func (*File) Read读文件

 func (f *File) Read(b []byte) (n int, err error)

Read方法从f中读取最多len(b)字节数据并写入b。它返回读取的字节数和可能遇到的任何错误。文件终止标志是读取0个字节且返回值err为io.EOF。

  • func (*File) ReadAt从指定位置读文件

 func (f *File) ReadAt(b []byte, off int64) (n int, err error)

ReadAt从指定的位置(相对于文件开始位置)读取len(b)字节数据并写入b。它返回读取的字节数和可能遇到的任何错误。当n<len(b)时,本方法总是会返回错误;如果是因为到达文件结尾,返回值err会是io.EOF。

  • func (*File) Write写入字节数据

func (f *File) Write(b []byte) (n int, err error)

Write向文件中写入len(b)字节数据。它返回写入的字节数和可能遇到的任何错误。如果返回值n!=len(b),本方法会返回一个非nil的错误。

  • func (*File) WriteString

 func (f *File) WriteString(s string) (ret int, err error)

WriteString类似Write,但接受一个字符串参数。

  • func (*File) WriteAt在指定位置写文件

 func (f *File) WriteAt(b []byte, off int64) (n int, err error)

WriteAt在指定的位置(相对于文件开始位置)写入len(b)字节数据。它返回写入的字节数和可能遇到的任何错误。如果返回值n!=len(b),本方法会返回一个非nil的错误。

  • func (*File) Seek

 func (f *File) Seek(offset int64, whence int) (ret int64, err error)

Seek设置下一次读/写的位置。offset为相对偏移量,而whence决定相对位置:0为相对文件开头,1为相对当前位置,2为相对文件结尾。它返回新的偏移量(相对开头)和可能的错误。

  • func (*File) Sync

 func (f *File) Sync() (err error)

Sync递交文件的当前内容进行稳定的存储。一般来说,这表示将文件系统的最近写入的数据在内存中的拷贝刷新到硬盘中稳定保存。写文件

  • func OpenFile

 func OpenFile(name string, flag int, perm FileMode) (file *File, err error)

OpenFile是一个更一般性的文件打开函数,大多数调用者都应用Open或Create代替本函数。它会使用指定的选项(如O_RDONLY等)、指定的模式(如0666等)打开指定名称的文件。如果操作成功,返回的文件对象可用于I/O。如果出错,错误底层类型是*PathError。

name string文件名

flag int文件打开模式

per FileMode权限控制(win中无效)

 const (
     O_RDONLY int = syscall.O_RDONLY // 只读模式打开文件
     O_WRONLY int = syscall.O_WRONLY // 只写模式打开文件
     O_RDWR   int = syscall.O_RDWR   // 读写模式打开文件
     O_APPEND int = syscall.O_APPEND // 写操作时将数据附加到文件尾部
     O_CREATE int = syscall.O_CREAT  // 如果不存在将创建一个新文件
     O_EXCL   int = syscall.O_EXCL   // 和O_CREATE配合使用,文件必须不存在
     O_SYNC   int = syscall.O_SYNC   // 打开文件用于同步I/O
     O_TRUNC  int = syscall.O_TRUNC  // 如果可能,打开时清空文件
 )

func Copy拷贝

func Copy(dst Writer, src Reader) (written int64, err error)

将src的数据拷贝到dst,直到在src上到达EOF或发生错误。返回拷贝的字节数和遇到的第一个错误。

对成功的调用,返回值err为nil而非EOF,因为Copy定义为从src读取直到EOF,它不会将读取到EOF视为应报告的错误。如果src实现了WriterTo接口,本函数会调用src.WriteTo(dst)进行拷贝;否则如果dst实现了ReaderFrom接口,本函数会调用dst.ReadFrom(src)进行拷贝。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值