回答:
func ReadFile(filename string) ([]byte, error)
ReadFileは、filenameで指定されたファイルを読み取り、その内容を返します。呼び出しが成功すると、err == EOFではなく、err == nilが返されます。ReadFileはファイル全体を読み取るため、ReadからのEOFを報告されるエラーとして扱いません。
の[]byte
代わりにを取得しstring
ます。本当に必要な場合は変換できます。
s := string(buf)
内容string
をそのままにするReadFile
場合は、io/ioutil
パッケージの関数を使用するのが簡単な解決策です。この関数は、bytes
簡単にに変換できるスライスを返しますstring
。
package main
import (
"fmt"
"io/ioutil"
)
func main() {
b, err := ioutil.ReadFile("file.txt") // just pass the file name
if err != nil {
fmt.Print(err)
}
fmt.Println(b) // print the content as 'bytes'
str := string(b) // convert content to a 'string'
fmt.Println(str) // print the content as a 'string'
}
これらのファイルすべてを連結する効率を本当に心配している場合は、すべてを同じバイトバッファーにコピーするのが最善の方法だと思います。
buf := bytes.NewBuffer(nil)
for _, filename := range filenames {
f, _ := os.Open(filename) // Error handling elided for brevity.
io.Copy(buf, f) // Error handling elided for brevity.
f.Close()
}
s := string(buf.Bytes())
これは、各ファイルを開き、その内容をbufにコピーしてから、ファイルを閉じます。実際の変換が不要な場合もありますが、最後の行は、buf.Bytes()に探しているデータがあることを示すだけです。
私はコンピューターを持っていないので、下書きを書きます。あなたは私の言うことをはっきりしているかもしれません。
func main(){
const dir = "/etc/"
filesInfo, e := ioutil.ReadDir(dir)
var fileNames = make([]string, 0, 10)
for i,v:=range filesInfo{
if !v.IsDir() {
fileNames = append(fileNames, v.Name())
}
}
var fileNumber = len(fileNames)
var contents = make([]string, fileNumber, 10)
wg := sync.WaitGroup{}
wg.Add(fileNumber)
for i,_:=range content {
go func(i int){
defer wg.Done()
buf,e := ioutil.Readfile(fmt.Printf("%s/%s", dir, fileName[i]))
defer file.Close()
content[i] = string(buf)
}(i)
}
wg.Wait()
}