1. सरल तार
"सरल" तार के लिए (आमतौर पर एक पंक्ति में जो फिट बैठता है) सबसे सरल समाधान का उपयोग कर रहा है fmt.Sprintf()
और दोस्तों ( fmt.Sprint()
, fmt.Sprintln()
)। ये स्टार्टर S
अक्षर के बिना फ़ंक्शन के अनुरूप हैं , लेकिन ये Sxxx()
वेरिएंट string
मानक आउटपुट पर प्रिंट करने के बजाय परिणाम लौटाते हैं ।
उदाहरण के लिए:
s := fmt.Sprintf("Hi, my name is %s and I'm %d years old.", "Bob", 23)
चर s
को मूल्य के साथ आरंभीकृत किया जाएगा:
Hi, my name is Bob and I'm 23 years old.
युक्ति: यदि आप विभिन्न प्रकारों के मानों को संक्षिप्त करना चाहते हैं, तो आपको स्वचालित रूप से उपयोग करने की आवश्यकता नहीं होगी Sprintf()
(जिसे प्रारूप स्ट्रिंग की आवश्यकता होती है) जैसा Sprint()
कि यह वास्तव में करता है। इस उदाहरण को देखें:
i := 23
s := fmt.Sprint("[age:", i, "]") // s will be "[age:23]"
केवल string
एस को समाप्त करने के लिए , आप भी उपयोग strings.Join()
कर सकते हैं जहां आप एक कस्टम विभाजक निर्दिष्ट कर सकते हैं string
(शामिल होने के लिए तार के बीच रखा जा सकता है)।
गो प्ले ग्राउंड पर इन्हें आज़माएं ।
2. जटिल तार (दस्तावेज)
यदि आप जिस स्ट्रिंग को बनाने की कोशिश कर रहे हैं वह अधिक जटिल है (उदाहरण के लिए एक बहु-पंक्ति ईमेल संदेश), fmt.Sprintf()
कम पठनीय और कम कुशल हो जाती है (विशेषकर यदि आपको ऐसा कई बार करना पड़ता है)।
इसके लिए मानक पुस्तकालय संकुल प्रदान करता है text/template
और html/template
। ये पैकेज टेक्स्ट-आउटपुट जेनरेट करने के लिए डेटा-संचालित टेम्प्लेट को लागू करते हैं। html/template
कोड इंजेक्शन के खिलाफ सुरक्षित HTML आउटपुट उत्पन्न करने के लिए है। यह पैकेज के रूप में एक ही इंटरफ़ेस प्रदान करता है text/template
और text/template
जब भी आउटपुट HTML होता है तो इसके बजाय इसका उपयोग किया जाना चाहिए ।
template
मूल रूप से पैकेजों का उपयोग करने के लिए आपको एक string
मूल्य के रूप में एक स्थिर टेम्पलेट प्रदान करना पड़ता है (जो किसी फ़ाइल से उत्पन्न हो सकता है, जिस स्थिति में आप केवल फ़ाइल नाम प्रदान करते हैं) जिसमें स्थैतिक पाठ हो सकता है, और जब संसाधित और निष्पादित की जाती हैं, तो कार्रवाई हो सकती है इंजन टेम्पलेट को प्रोसेस करता है और आउटपुट उत्पन्न करता है।
आप ऐसे पैरामीटर प्रदान कर सकते हैं जो स्थिर टेम्पलेट में शामिल / प्रतिस्थापित हैं और जो आउटपुट जनरेशन प्रक्रिया को नियंत्रित कर सकते हैं। ऐसे मापदंडों का विशिष्ट रूप struct
एस और map
मूल्य हैं जिन्हें नेस्टेड किया जा सकता है।
उदाहरण:
उदाहरण के लिए मान लें कि आप इस तरह दिखने वाले ईमेल संदेश उत्पन्न करना चाहते हैं:
Hi [name]!
Your account is ready, your user name is: [user-name]
You have the following roles assigned:
[role#1], [role#2], ... [role#n]
इस तरह से ईमेल संदेश निकाय बनाने के लिए, आप निम्नलिखित स्थैतिक टेम्पलेट का उपयोग कर सकते हैं:
const emailTmpl = `Hi {{.Name}}!
Your account is ready, your user name is: {{.UserName}}
You have the following roles assigned:
{{range $i, $r := .Roles}}{{if $i}}, {{end}}{{.}}{{end}}
`
और इसे निष्पादित करने के लिए इस तरह डेटा प्रदान करें:
data := map[string]interface{}{
"Name": "Bob",
"UserName": "bob92",
"Roles": []string{"dbteam", "uiteam", "tester"},
}
आम तौर पर टेम्प्लेट का आउटपुट io.Writer
ए के लिए लिखा जाता है , इसलिए यदि आप परिणाम के रूप में चाहते हैं, तो string
ए bytes.Buffer
(जो लागू होता है io.Writer
) बनाएं और लिखें । टेम्पलेट को निष्पादित करना और परिणाम प्राप्त करना string
:
t := template.Must(template.New("email").Parse(emailTmpl))
buf := &bytes.Buffer{}
if err := t.Execute(buf, data); err != nil {
panic(err)
}
s := buf.String()
यह अपेक्षित आउटपुट में परिणाम देगा:
Hi Bob!
Your account is ready, your user name is: bob92
You have the following roles assigned:
dbteam, uiteam, tester
इसे गो प्लेग्राउंड पर आज़माएं ।
यह भी ध्यान रखें कि जाओ 1.10, के बाद से एक नए, तेजी से, अधिक विशेष विकल्प उपलब्ध है bytes.Buffer
जो है: strings.Builder
। उपयोग बहुत समान है:
builder := &strings.Builder{}
if err := t.Execute(builder, data); err != nil {
panic(err)
}
s := builder.String()
इस एक को खेल के मैदान पर आज़माएं ।
नोट: यदि आप os.Stdout
लक्ष्य के रूप में प्रदान करते हैं (जो भी लागू होता है io.Writer
) तो आप टेम्पलेट निष्पादन का परिणाम भी प्रदर्शित कर सकते हैं :
t := template.Must(template.New("email").Parse(emailTmpl))
if err := t.Execute(os.Stdout, data); err != nil {
panic(err)
}
यह सीधे परिणाम को लिखेगा os.Stdout
। इसे गो प्लेग्राउंड पर आज़माएं ।