目錄相關(guān)
//目錄創(chuàng)建
Package os
func Mkdir(namestring, permFileMode)error {
//僅創(chuàng)建一層目錄
// Mkdir creates a new directory with the specified name and permission
// bits (before umask).
// If there is an error, it will be of type *PathError.
func MkdirAll(pathstring, permFileMode)error {
//創(chuàng)建多級目錄
// Fast path: if we can tell whether path is a directory or file, stop with success or error.
文件相關(guān)
讀取文件
//文件創(chuàng)建與刪除
func Create(namestring) (*File, error) {
//創(chuàng)建文件副女,如果文件存在將會被覆蓋
func Remove(namestring)error {
//刪除文件和空目錄
// Remove removes the named file or (empty) directory.
// If there is an error, it will be of type *PathError.
//文件讀寫操作
//讀取文件
方式一:
func Read0()(string){
f,err:=ioutil.ReadFile("file/test")
iferr!=nil{
fmt.Println("read fail",err)
}return string(f)
}
方式二:
func Read1() (string){
//獲得一個file
f, err := os.Open("file/test")
if err != nil {
fmt.Println("read fail")
return ""
}
//把file讀取到緩沖區(qū)中
defer f.Close()
var chunk []byte
buf := make([]byte, 1024)
for {
//從file讀取到buf中
n, err := f.Read(buf)
if err != nil && err != io.EOF{
fmt.Println("read buf fail", err)
return ""
}
//說明讀取結(jié)束
if n == 0 {
break
}
//讀取到最終的緩沖區(qū)中
chunk = append(chunk, buf[:n]...)
}
return string(chunk)
//fmt.Println(string(chunk))
}
方式三:
//先從文件讀取到file, 在從file讀取到Reader中枕赵,從Reader讀取到buf, buf最終追加到[]byte
func Read2() (string) {
fi, err := os.Open("file/test")
if err != nil {
panic(err)
}
defer fi.Close()
r := bufio.NewReader(fi)
var chunks []byte
buf := make([]byte, 1024)
for {
n, err := r.Read(buf)
if err != nil && err != io.EOF {
panic(err)
}
if 0 == n {
break
}
//fmt.Println(string(buf))
chunks = append(chunks, buf...)
}
return string(chunks)
//fmt.Println(string(chunks))
}
方式四:
func Read3() (string){
f, err := os.Open("file/test")
if err != nil {
fmt.Println("read file fail", err)
return ""
}
defer f.Close()
fd, err := ioutil.ReadAll(f)
if err != nil {
fmt.Println("read to fd fail", err)
return ""
}
return string(fd)
}
效率:方式四 > 方式一 > 方式三 > 方式四
寫入文件
方式一:
func Write0() {
fileName := "file/test1"
strTest := "測試測試"
var f *os.File
var err error
if CheckFileExist(fileName) { //文件存在
f, err = os.OpenFile(fileName, os.O_APPEND, 0666) //打開文件
if err != nil{
fmt.Println("file open fail", err)
return
}
}else { //文件不存在
f, err = os.Create(fileName) //創(chuàng)建文件
if err != nil {
fmt.Println("file create fail")
return
}
}
//將文件寫進(jìn)去
n, err1 := io.WriteString(f, strTest)
if err1 != nil {
fmt.Println("write error", err1)
return
}
fmt.Println("寫入的字節(jié)數(shù)是:", n)
}
方式二:
func Write1() {
fileName := "file/test2"
strTest := "測試測試"
var d = []byte(strTest)
err := ioutil.WriteFile(fileName, d, 0666)
if err != nil {
fmt.Println("write fail")
}
fmt.Println("write success")
}
方式三:
func Write2() {
fileName := "file/test3"
strTest := "測試測試"
var d1 = []byte(strTest)
f, err3 := os.Create(fileName) //創(chuàng)建文件
if err3 != nil{
fmt.Println("create file fail")
}
defer f.Close()
n2, err3 := f.Write(d1) //寫入文件(字節(jié)數(shù)組)
fmt.Printf("寫入 %d 個字節(jié)n", n2)
n3, err3 := f.WriteString("writesn") //寫入文件(字節(jié)數(shù)組)
fmt.Printf("寫入 %d 個字節(jié)n", n3)
f.Sync()
}
方式四:
func Write3() {
fileName := "file/test3"
f, err3 := os.Create(fileName) //創(chuàng)建文件
if err3 != nil{
fmt.Println("create file fail")
}
w := bufio.NewWriter(f) //創(chuàng)建新的 Writer 對象
n4, err3 := w.WriteString("bufferedn")
fmt.Printf("寫入 %d 個字節(jié)n", n4)
w.Flush()
f.Close()
}