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.TrimSuffix 。
|
fmt.Println(strings.TrimSuffix(filename, ext))
|
Rel 會找出 基礎 和 目標 之間的相對路徑。如果無法讓目標相對於基礎,則會回傳錯誤。
|
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)
}
|