Golang學習 - io/ioutil 包

------------------------------------------------------------

// Discard 是一個 io.Writer 接口,調用它的 Write 方法將不作任何事情
// 而且始終成功返回。
var Discard io.Writer = devNull(0)

// ReadAll 讀取 r 中的全部數據,返回讀取的數據和遇到的錯誤。
// 若是讀取成功,則 err 返回 nil,而不是 EOF,由於 ReadAll 定義爲讀取
// 全部數據,因此不會把 EOF 當作錯誤處理。
func ReadAll(r io.Reader) ([]byte, error)

// ReadFile 讀取文件中的全部數據,返回讀取的數據和遇到的錯誤。
// 若是讀取成功,則 err 返回 nil,而不是 EOF
func ReadFile(filename string) ([]byte, error)

// WriteFile 向文件中寫入數據,寫入前會清空文件。
// 若是文件不存在,則會以指定的權限建立該文件。
// 返回遇到的錯誤。
func WriteFile(filename string, data []byte, perm os.FileMode) error

// ReadDir 讀取指定目錄中的全部目錄和文件(不包括子目錄)。
// 返回讀取到的文件信息列表和遇到的錯誤,列表是通過排序的。
func ReadDir(dirname string) ([]os.FileInfo, error)

// NopCloser 將 r 包裝爲一個 ReadCloser 類型,但 Close 方法不作任何事情。
func NopCloser(r io.Reader) io.ReadCloser

// TempFile 在 dir 目錄中建立一個以 prefix 爲前綴的臨時文件,並將其以讀
// 寫模式打開。返回建立的文件對象和遇到的錯誤。
// 若是 dir 爲空,則在默認的臨時目錄中建立文件(參見 os.TempDir),屢次
// 調用會建立不一樣的臨時文件,調用者能夠經過 f.Name() 獲取文件的完整路徑。
// 調用本函數所建立的臨時文件,應該由調用者本身刪除。
func TempFile(dir, prefix string) (f *os.File, err error)

// TempDir 功能同 TempFile,只不過建立的是目錄,返回目錄的完整路徑。
func TempDir(dir, prefix string) (name string, err error)

------------------------------

// 示例:讀取目錄
func main() {
	rd, err := ioutil.ReadDir("/")
	fmt.Println(err)
	for _, fi := range rd {
		if fi.IsDir() {
			fmt.Printf("[%s]\n", fi.Name())

		} else {
			fmt.Println(fi.Name())
		}
	}
}

------------------------------

// 示例:臨時目錄、臨時文件
func main() {
	// 建立臨時目錄
	dir, err := ioutil.TempDir("", "Test")
	if err != nil {
		fmt.Println(err)
	}
	defer os.Remove(dir) // 用完刪除
	fmt.Printf("%s\n", dir)

	// 建立臨時文件
	f, err := ioutil.TempFile(dir, "Test")
	if err != nil {
		fmt.Println(err)
	}
	defer os.Remove(f.Name()) // 用完刪除
	fmt.Printf("%s\n", f.Name())
}

------------------------------------------------------------



相關文章
相關標籤/搜索