os包的地址:https://pkg.go.dev/os@go1.19.5
os包的作用:Package os provides a platform-independent interface to operating system functionality. The design is Unix-like, although the error handling is Go-like; failing calls return values of type error rather than error numbers. Often, more information is available within the error. For example, if a call that takes a file name fails, such as Open or Stat, the error will include the failing file name when printed and will be of type *PathError, which may be unpacked for more information.
首先理清文件读取的流程
1.读
a.文件位置
b.打开文件
   file, err := os.Open(path)     (file 为*os.File类型)     os.Open(path) 打开的文件是只读模式!
c.读取文件内容(定义每次读取的字节数)
   file.Read(b []btye)
   (io.EOF 是当没有更多的输入可获得时返回的错误(Read必须返回io.EOF本身,而非一个包装了EOF错误,因为调用者会使用 == 来测试 EOF),函数应该返回EOF来优雅地提示输入的结束)
d.关闭文件
    file.Close()
2.写
a.创建文件
    os.Create(path)
b.写入内容
   file.Write(b  []byte)  /   file.WriteString(s string) 
c.关闭文件
   file.Close()
关于文件路径:
       绝对路径:程序不管在什么位置运行,操作的文件都不会发生变化(从根路径开始/盘符开始书写的路径)
      相对路径:与程序的位置有关(程序运行的位置)    ./xxxx( 或xxxx):当前目录下  ../xxxx:  父目录  
                        程序放置的位置 c:/golangcode/main.exe
                        程序运行的位置 e:/ c:/golangcode/main.exe
File类型
注意以下两个函数的区别:
https://stackoverflow.com/questions/69257525/golang-csv-write-not-writing-but-no-errors
函数:os.Open(name string)  (*File, error)
作用:打开已命名的文件,返回的文件只可以用于读;相关的文件描述词有O_RDONLY 模式(即默认模式)。如果出现错误,则返回的为*PathError类型。
函数:os.OpenFile(name string, flag int, perm FileMode) (*File, error)
作用:OpenFile是全面性的打开open call,绝大多数的使用者会使用Open或Create。它打开带有特定flag(O_RDONLY等等)的已命名的文件。如果文件不存在,并且O_CREATE flag被传递进来,它会使用perm mode(在umask之前)创建。如果调用成功,方法返回的文件可以被用于I/O;如果出现错误,则返回的为*PathError类型。
OpenFile所有的Flag:
①.O_RDONLY– Read-Only Mode
②.O_WRONLY. Opens file in Write Only mode
③.O_RDWR–Open the file in Read-Write mode
④.O_APPEND–Appends data to the file when writing
⑤.O_TRUNC–Truncate the file when opened, where applicable
⑥.O_SYNC – Open the file for synchronous I/O
⑦.O_CREATE – Create a file if it does not exist
perm(FileMode)为文件的模式和权限
os中定义的常量:
os.ModeDir
os.ModeType
os.ModePerm
............
Common Permission Usages
0755 Commonly used on web servers. The owner can read, write, execute. Everyone else can read and execute but not modify the file.
0777 Everyone can read write and execute. On a web server, it is not advisable to use ‘777’ permission for your files and folders, as it allows anyone to add malicious code to your server.
0644 Only the owner can read and write. Everyone else can only read. No one can execute the file.
0655 Only the owner can read and write, but not execute the file. Everyone else can read and execute, but cannot modify the file.

函数:os.Seek(offset int64, whence int) (ret int64, err error)
作用:Seek设置下一次文件中的读或写的开端,根据whence的值来进行解读:
           0意味着相对文件的起始位置;
           1意味着相对于当前的开端;
           2意味着相对于文件的末尾。
   Seek方法返回偏移后的位置(offset)和一个error
---------------------------------------------------------------------------------------------------------------
os包中与文件操作相关的方法:
1.os.Rename
函数:func Rename(oldpath, newpath string) error
           Rename将旧路径更名到新路径。如果新路径已存并且不是一个目录,Rename将会替代它。当旧路径和新路径在不同的目录中时,特定操作系统的限制也许会适用。如果发生错误,它将会返回一个*LinkError类型。
2.os.Remove / os.RemoveAll
函数:func  Remove(name string)  error
           Remove移除命名的文件或(空的)目录。如果发生错误,它将会返回一个*PathError类型。
函数:func RemoveAll(path string) error
           RemoveAll移除路径以及它所包含的任何子元素。它移除一切可以移除的,但会返回它所遇到的一个错误。如果路径不存在,RemoveAll返回nil(no error)。如果发生错误,它将会返回一个*PathError类型。
3.os.Mkdir
函数:func Mkdir(name string, perm FileMode)  error
           Mkdir使用特定的name和权限位来创建目录,如果发生错误,它将会返回一个*PathError类型。
os.MkdirAll
函数:func MkdirAll(path string, perm FileMode) error
           MkdirAll创建目录命名路径,以及任何有必要的父目录,并返回nil或者一个error。权限位用于所有MkdirAll创建的目录。如果路径已经存在一个目录,MkdirAll将会什么都不做,并返回nil。
------------
File.Readdir
方法:func (f *File) Readdir(nint) ([]FileInfo,error)
          Readdir 读取与文件相关的目录的内容,并且返回一个向上的n个FileInfo值,由Lstat返回,并且以目录的顺序。后续在相同的文件上的调用会屈服于进一步的FileInfos。
       如果n > 0, Readdir返回至多n个FileInfo结构体。在这种情况之下,如果Readdir返回一个空的切片,它会返回一个非nil错误来解释为什么。在目录的结尾,这个错误是io.EOF。
       如果n ≤ 0, Readdir在一个切片中返回目录中所有的FileInfo。在这种情况下,如果Readdir成功(读取直到目录的结尾),它返回切片和一个nil错误。如果它在目录结束之前遇到一个错误,Readdir返回读取到该点的FileInfo和非nil错误。
       大部分的clients更好地被更有效率的ReadDir所服务。
------------
4.os.IsNotExist
函数:func IsNotExist(err error)  bool
          IsNotExist返回一个bool值,以显示error表明一个文件或目录不存在。
5.os.Stat
函数:func Stat(name string) (FileInfo, error)
           Stat返回一个FileInfo来描述命名的文件,如果发生错误,它将会返回一个*PathError类型。
           (FileInfo常用方法:Name()  Size()  ModTime()  lsDir()  Mode())
Lstat
函数:func Lstat(name string) (FileInfo, error)
           Lstat返回一个FileInfo来描述命名的文件。如果文件是一个符号链接,则它返回的FileInfo描述符号链接。Lstat不会尝试跟进这个链接。如果发生错误,它将会返回一个*PathError类型。
6.os.Truncate
函数:func Truncate(name string, size int64) error
           Truncate改变命名文件的大小。如果文件是一个符号链接,它改变连接对应目标的大小。如果这里有错误,它将会是一个*PathError类型。
7.os.TempDir
函数:func TempDir() string
           TempDir返回默认目录来存放临时文件。
8.os.UserHomeDir
函数:func UserHomeDir() (string, error)
          UserHomeDir返回当前用户的主目录。
(有可能你会写一些程序,或者你的文件程序放到缓存目录/临时目录/用户目录,要获取这三个目录,可以用TempDir / UserHomeDir )
io/ioutil(工具方法)包的地址:https://pkg.go.dev/io/ioutil@go1.19.5
io/ioutil包的作用:实现一些I/O的应用方法(不提倡使用;相同的函数,已由io包或os包提供,并且这些应用应该在新代码中优先)
该包已弃用,推荐使用os包内的函数:

