Respostas:
Use ioutil.ReadFile
:
func ReadFile(filename string) ([]byte, error)
ReadFile lê o arquivo nomeado pelo nome do arquivo e retorna o conteúdo. Uma chamada bem-sucedida retorna err == nil, não err == EOF. Como o ReadFile lê o arquivo inteiro, ele não trata um EOF de Read como um erro a ser relatado.
Você receberá um em []byte
vez de um string
. Pode ser convertido se realmente necessário:
s := string(buf)
Se você deseja apenas o conteúdo como string
, a solução simples é usar a ReadFile
função do io/ioutil
pacote. Essa função retorna uma fatia da bytes
qual você pode facilmente converter em a 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'
}
Acho que a melhor coisa a fazer, se você estiver realmente preocupado com a eficiência da concatenação de todos esses arquivos, é copiá-los no mesmo buffer de bytes.
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())
Isso abre cada arquivo, copia seu conteúdo para o buf e depois fecha o arquivo. Dependendo da sua situação, talvez você não precise convertê-la, a última linha é apenas para mostrar que o buf.Bytes () tem os dados que você está procurando.
Não estou com computador, então escrevo um rascunho. Você pode ter certeza do que eu digo.
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()
}