Go语言 文件操作

首先获取文件名,借助os包中都得stat()函数来获取文件属性信息,在函数返回的文件属性中包含文件名和文件大小,Stat参数中name传入的是文件访问的绝对路径,FileInfo中的Name()函数可以将文件名单独提取出来

os.Stat

func (f *File) Stat() (fi FileInfo, err error)

Stat返回描述文件f的FileInfo类型值。如果出错,错误底层类型是*PathError。

type FileInfo 

type FileInfo interface {
    Name() string       // 文件的名字(不含扩展名)
    Size() int64        // 普通文件返回值表示其大小;其他文件的返回值含义各系统不同
    Mode() FileMode     // 文件的模式位
    ModTime() time.Time // 文件的修改时间
    IsDir() bool        // 等价于Mode().IsDir()
    Sys() interface{}   // 底层数据来源(可以返回nil)
}

fileInfo用来描述一个文件对象。

func main(){
	fileinfo, err := os.Stat("/home/wxy/桌面/debug.txt")
	if err != nil{
		fmt.Println(err)
		return
	}
	fmt.Printf("%T \n", fileinfo) //*os.fileStat 

	fileName := fileinfo.Name()
	fmt.Println(fileName) // debug.txt

	fileSize := fileinfo.Size()
	fmt.Println(fileSize)

	isDir := fileinfo.IsDir()
	fmt.Println(isDir) // false

	fileModTime := fileinfo.ModTime()
	fmt.Println(fileModTime) // 

	fileMode := fileinfo.Mode()
	fmt.Println(fileMode) // -rw-r--r--

}

filepath.IsAbs

判断文件是否绝对路径

file := "/home/wxy/桌面/debug.txt"
file2 := "a.txt"

fmt.Println(filepath.IsAbs(file))  //Ture
fmt.Println(filepath.IsAbs(file2))  //False

filepath.Abs

获取文件绝对路径

	file := "/home/wxy/桌面/debug.txt"
	file2 := "a.txt"

	fileabs, err := filepath.Abs(file)
	if err != nil{
		fmt.Println(err)
	}
	fmt.Println(fileabs)
	fileabs, err = filepath.Abs(file2)
	if err != nil{
		fmt.Println(err)
	}
	fmt.Println(fileabs)  // /home/wxy/go/src/test/a.txt

path.Join

获取文件的上层或上上层路径

	file := "/home/wxy/桌面/debug.txt"
	fileparent := path.Join(file, "../..")
	fmt.Println(fileparent)  // /home/wxy

path.Dir

获取文件的父级路径

	file := "/home/wxy/桌面/debug.txt"
	fileparent = path.Dir(file)
	fmt.Println(fileparent)  // /home/wxy/桌面

获取执行文件路径

func main(){
	basefile, err := exec.LookPath(os.Args[0])
	if err != nil{
		fmt.Println(err)
	}

	basepath, err:= filepath.Abs(basefile)
	if err != nil{
		fmt.Println(err)
	}
    fmt.Println(basepath)

	parentpath := path.Dir(basepath)
	fmt.Println(parentpath)

}

os.Mkdir

创建目录

	err = os.Mkdir("/home/wxy/go/src/test/dir",os.ModePerm)  // os.ModePerm 文件夹777权限
	if err != nil{
		fmt.Println(err)
	}

 注意:若文件目录存在则报错

os.MkdirAll

创建多层目录,类似 mkdir -p

	err = os.MkdirAll("/home/wxy/go/src/test/dir/a/b/c", os.ModePerm)
	if err != nil{
		fmt.Println(err)
	}

注意:目录存在不会报错

文件编辑

文件打开模式

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   // 打开文件用于同步IO.
	O_TRUNC  int = syscall.O_TRUNC  // 如果可能,打开时清空文件.
)

os.create 创建文件

func create (name string) (file *File, err error)

create采用模式0666(任何人都可读写,不可执行)创建一个名为name的文件,如果文件已存在会截断它(为空文件)
如果成功,返回的文件对象可用于I/0;对应的文件描述符具有0_RDWR模式。如果出错,错误底层类型是*PathError

func main(){
	fileName := "b.txt"
	file, err := os.Create(fileName)
	if err != nil{
		fmt.Println(err)
	}
	fmt.Printf("%T \n",file) //*os.File
}

os.Open 只读模式打开文件

func Open (name string) (file *File, err error)

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

func main(){
	fileName := "b.txt"
	file, err := os.Open(fileName)
	if err != nil{
		fmt.Println(err)
	}
	fmt.Println(file.Name())

    file.Close()  // 关闭文件,打开的文件操作完要关闭
}

os.OpenFile 可配置文件打开模式

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

相对于os.Open多了文件打卡模式参数和打开权限参数,它会使用指定的选项(如0_RDONLY等)、指定的模式(如9666等)打开指定名称的文件。如果操作成功,返回的文件对象可用于I/0。如果出错,错误
底层类型是*PathError。

func main(){
	fileName := "b.txt"
	file, err := os.OpenFile(fileName,os.O_RDONLY|os.O_WRONLY,os.ModePerm)
	if err != nil{
		fmt.Println(err)
	}
	fmt.Println(file.Name())
    file.Close()
}

参数 os.O_RDONLY|os.O_WRONLY 表示以读模式和写模式打开
    os.ModePerm 表示打开权限 0777

file.Read 读取文件内容

func (f *File) Read(b []byte) (n int, err error) 
func main(){
	fileName := "a.txt"
    //打开文件
	file, err := os.Open(fileName)
	if err != nil{
		fmt.Println(err)
	}
    //创建[]byte用来缓存文件内容
	buf := make([]byte,4069)
    //将文件内容读到[]byte中
	n, err := file.Read(buf)
	if err != nil{
		fmt.Println(err)
	}
	content := string(buf[:n])
    file.Close()
	fmt.Println(content)
}

file.Write 向文件内写入文本

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

参数是[]byte类型的字节,需要将文本转为[]byte类型,返回的n是写入的字节数量

func main(){
	fileName := "a.txt"
	file, err := os.OpenFile(fileName, os.O_CREATE|os.O_WRONLY|os.O_APPEND, os.ModePerm)
	if err != nil{
		fmt.Println(err)
	}
	content := []byte("hello goland 123 ....")
	file.Write(content)
	file.Close()
}

os.O_WRONLY|os.O_APPEND 表示以写模式打开文件,并且写入的内容是向末尾追加

os.Remove 删除文件或文件夹

func Remove(name string) error 

删除文件时,可直接删除,若删除的是目录,需要这个目录是空目录,否则报错无法删除,可以选择使用os.RemoveAll强制删除 

os.Remove和os.RemoveAll删除的内容无法找回,类似rm -rf

func main(){
	fileName := "bb.txt"
	err := os.Remove(fileName)
	if err != nil{
		fmt.Println(err)
	}
}

os.Rename 文件或文件夹重名

func Rename(oldpath, newpath string) error

重命名不影响文件或文件夹的内容 

func main(){
	dirName := "/home/wxy/go/src/test/dir/a/b/c"
	newdirName := "/home/wxy/go/src/test/dir/a/b/cc"
	err := os.Rename(dirName, newdirName)
	if err != nil{
		fmt.Println(err)
	}
}

io.Copy 文件拷贝

package main

import (
	"fmt"
	"io"
	"os"
)

func main() {

	CopyFile()
}

func CopyFile(){
	file1, err := os.Open("test.jpg")
	if err != nil{
		fmt.Println(err)
	}
	file2, err := os.OpenFile("cptest.jpg", os.O_CREATE|os.O_WRONLY|os.O_APPEND, os.ModePerm)
	if err != nil{
		fmt.Println(err)
	}
	n, err := io.Copy(file2, file1)
	if err != nil{
		fmt.Println(err)
	}
	fmt.Println(n)
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 使用Go语言实现文件传输可以使用net/http包的HandleFile函数。它可以接受一个文件路径,然后将文件内容作为响应发送给客户端。下面是一个简单的示例:http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) { http.ServeFile(w, r, "./myfile.txt") }) ### 回答2: 使用Go语言实现文件传输可以通过以下步骤进行: 1. 导入所需的包:在Go语言中,使用`os`包操作文件系统,使用`net`包进行网络通信。 2. 创建TCP服务器:使用`net.Listen`函数创建一个TCP服务器,并指定监听的地址和端口。 3. 监听客户端连接:使用`Accept`方法在服务器上监听客户端的连接请求,并创建一个新的TCP连接。 4. 接收文件数据:使用`io.Copy`函数从客户端连接中读取文件数据,并保存到本地的文件中。 5. 关闭连接:在文件传输完成后,关闭连接。 以下是一个简单的示例代码: ```go package main import ( "fmt" "io" "net" "os" ) func main() { // 创建TCP服务器 listener, err := net.Listen("tcp", "localhost:8000") if err != nil { fmt.Println("Error listening:", err.Error()) os.Exit(1) } defer listener.Close() fmt.Println("Server started. Listening on localhost:8000") // 监听客户端连接 conn, err := listener.Accept() if err != nil { fmt.Println("Error accepting connection:", err.Error()) os.Exit(1) } defer conn.Close() fmt.Println("Client connected.") // 创建文件来保存接收到的数据 outputFile, err := os.Create("output.txt") if err != nil { fmt.Println("Error creating file:", err.Error()) os.Exit(1) } defer outputFile.Close() // 接收文件数据并保存到指定文件中 _, err = io.Copy(outputFile, conn) if err != nil { fmt.Println("Error receiving file:", err.Error()) os.Exit(1) } fmt.Println("File transfer complete.") } ``` 以上代码演示了一个简单的文件传输服务器端,它会监听在本地的8000端口上,等待客户端连接。一旦有客户端连接,它会接收该客户端传输的文件,并将文件保存在本地的`output.txt`文件中。在实际生产环境中,你可能需要添加更多的错误处理和安全性措施。 ### 回答3: 使用Go语言实现文件传输可以通过以下步骤完成: 1. 导入所需的包:使用Go语言实现文件传输需要使用`net`和`os`包,分别用于处理网络连接和操作系统相关的文件操作。 2. 创建服务器端:使用`net`包中的`Listen`函数创建一个`net.Listener`对象,指定服务器要监听的端口和IP地址。用`Accept`方法接受客户端的连接,并使用`io.Copy`方法将收到的文件写入到服务器上的目标文件。 3. 创建客户端:使用`net`包中的`Dial`方法连接到服务器的IP地址和端口号。打开本地文件,并使用`io.Copy`方法将文件内容发送给服务器。 4. 异常处理:在编写代码时,应对可能出现的错误进行适当的异常处理,例如检查文件是否存在、网络连接是否正常以及读写文件时是否发生错误。 5. 测试代码:编写测试代码以验证文件传输功能是否正常工作。可以模拟服务器和客户端之间的文件传输,检查传输的文件是否一致。 总结:使用Go语言实现文件传输需要使用`net`和`os`包,通过创建服务器端和客户端的代码,实现文件的发送和接收。在编写代码时要注意异常处理,并进行测试以验证文件传输功能的正确性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值