У меня много маленьких файлов, я не хочу читать их построчно.
Есть ли в Go функция, которая будет читать весь файл в строковую переменную?
У меня много маленьких файлов, я не хочу читать их построчно.
Есть ли в Go функция, которая будет читать весь файл в строковую переменную?
 Используйте  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() имеет данные, которые вы ищете.
Вот как я это сделал:
package main
import (
  "fmt"
  "os"
  "bytes"
  "log"
)
func main() {
   filerc, err := os.Open("filename")
   if err != nil{
     log.Fatal(err)
   }
   defer filerc.Close()
   buf := new(bytes.Buffer)
   buf.ReadFrom(filerc)
   contents := buf.String()
   fmt.Print(contents) 
}    
		Я не с компьютером, поэтому я пишу черновик. Вы можете быть ясно из того, что я говорю.
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()
}