Go では、ファイルを個別に配布するのではなく、コンパイルされた実行可能ファイル内に含めたいシナリオに遭遇することがあります。このガイドでは、Go バイナリにファイルを埋め込むための 2 つの方法、go:embed ディレクティブと go generated コマンドを使用する方法について説明します。
Go 1.16 で導入された go: embed ディレクティブは、ファイルをバイナリに埋め込む簡単な方法を提供します。このディレクティブを使用すると、埋め込みファイルを文字列、バイト スライス、または embed.FS タイプとして保持する変数を直接定義できます。例:
import "embed" //go:embed hello.txt var s string
go:embed を使用すると、特に複数のファイルや動的に生成されたファイルを扱う場合に、ファイルの埋め込みプロセスが合理化されます。
Go 1.16 より前では、 go generated コマンドはファイルを埋め込むための代替方法を提供していました。この方法には、ファイルを読み取り、埋め込みファイルを文字列リテラルとして含む Go ファイルを生成するカスタム スクリプトの作成が含まれます。
Go ファイルを生成するスクリプトを作成します:
別のスクリプト ファイルで、テキスト ファイルを読み取り、文字列リテラルとして新しいファイルに書き込みます。例:
package main import ( "fmt" "io/ioutil" "os" "strings" ) // Reads all .txt files in the current folder // and encodes them as string literals in textfiles.go func main() { fs, _ := ioutil.ReadDir(".") out, _ := os.Create("textfiles.go") out.Write([]byte("package main \n\nconst (\n")) for _, f := range fs { if strings.HasSuffix(f.Name(), ".txt") { out.Write([]byte(strings.TrimSuffix(f.Name(), ".txt") + " = `")) f, _ := os.Open(f.Name()) io.Copy(out, f) out.Write([]byte("`\n")) } } out.Write([]byte(")\n")) }
メイン Go ファイルに特別なコメントを追加します。
メイン Go に go generated コマンドを含む特別なコメントを追加します。ファイル。このコメントは、コンパイル前に指定されたスクリプトを実行するように Go に指示します。
//go:generate go run scripts/includetxt.go
go Generate は柔軟性が高く、go:embed は Go バイナリにファイルを埋め込むためのより現代的で便利なアプローチです。開発ニーズに最も適した方法を選択してください。
以上が「go:embed」と「gogenerate」を使用して Go バイナリにファイルを埋め込むにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。