Skip to content

文件路径

filepath 包为 文件路径 ,提供了方便的跨操作系统的解析和构建函数; 比如:Linux 下的 dir/file 和 Windows 下的 dir\file 。

代码示例

package main

import (
    "fmt"
    "path/filepath"
    "strings"
)

func main() {

    // 应使用 Join 来构建可移植(跨操作系统)的路径。 它接收任意数量的参数,并参照传入顺序构造一个对应层次结构的路径。
    p := filepath.Join("dir1", "dir2", "filename")
    fmt.Println("p:", p)

    // 您应该总是使用 Join 代替手动拼接 / 和 \。 除了可移植性,Join 还会删除多余的分隔符和目录,使得路径更加规范。
    fmt.Println(filepath.Join("dir1//", "filename"))
    fmt.Println(filepath.Join("dir1/../dir1", "filename"))

    // Dir 和 Base 可以被用于分割路径中的目录和文件。 此外,Split 可以一次调用返回上面两个函数的结果。
    fmt.Println("Dir(p):", filepath.Dir(p))
    fmt.Println("Base(p):", filepath.Base(p))

    // 判断路径是否为绝对路径。
    fmt.Println(filepath.IsAbs("dir/file"))
    fmt.Println(filepath.IsAbs("/dir/file"))

    filename := "config.json"

    // 某些文件名包含了扩展名(文件类型)。 我们可以用 Ext 将扩展名分割出来。
    ext := filepath.Ext(filename)
    fmt.Println(ext)

    // 想获取文件名清除扩展名后的值,请使用 strings.TrmSuffix。
    fmt.Println(strings.TrimSuffix(filename, ext))

    // Rel 寻找 basepath 与 targpath 之间的相对路径。 如果相对路径不存在,则返回错误。
    rel, err := filepath.Rel("a/b", "a/b/t/file")
    if err != nil {
        panic(err)
    }
    fmt.Println(rel)

    rel, err = filepath.Rel("a/b", "a/c/t/file")
    if err != nil {
        panic(err)
    }
    fmt.Println(rel)
}

执行结果

$ go run file-paths.go
p: dir1/dir2/filename
dir1/filename
dir1/filename
Dir(p): dir1/dir2
Base(p): filename
false
true
.json
config
t/file
../c/t/file