Ответы:
Используйте ioutil.ReadFile
:
func ReadFile(filename string) ([]byte, error)
ReadFile читает файл с именем filename и возвращает его содержимое. Успешный вызов возвращает err == nil, а не err == EOF. Поскольку ReadFile читает весь файл, он не рассматривает EOF из Read как ошибку, о которой будет сообщено.
Вы получите []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()
}