अमृत - तार
एलिक्जिर में स्ट्रिंग्स को दोहरे उद्धरण चिह्नों के बीच डाला गया है, और वे UTF-8 में एन्कोडेड हैं। C और C ++ के विपरीत, जहां डिफ़ॉल्ट स्ट्रिंग्स ASCII एन्कोडेड हैं और केवल 256 विभिन्न वर्ण संभव हैं, UTF-8 में 1,112,064 कोड बिंदु हैं। इसका मतलब है कि UTF-8 एन्कोडिंग में कई अलग-अलग संभावित अक्षर होते हैं। चूंकि तार utf-8 का उपयोग करते हैं, हम प्रतीकों का उपयोग भी कर सकते हैं जैसे: ö, ł, आदि।
एक स्ट्रिंग बनाएँ
एक स्ट्रिंग चर बनाने के लिए, बस एक चर को स्ट्रिंग असाइन करें -
str = "Hello world"
इसे अपने कंसोल पर प्रिंट करने के लिए, बस कॉल करें IO.puts फ़ंक्शन और इसे चर str पास करें -
str = str = "Hello world"
IO.puts(str)
उपरोक्त कार्यक्रम निम्नलिखित परिणाम उत्पन्न करता है -
Hello World
खाली स्ट्रिंग्स
आप स्ट्रिंग शाब्दिक का उपयोग कर एक खाली स्ट्रिंग बना सकते हैं, ""। उदाहरण के लिए,
a = ""
if String.length(a) === 0 do
IO.puts("a is an empty string")
end
उपरोक्त कार्यक्रम निम्नलिखित परिणाम उत्पन्न करता है।
a is an empty string
स्ट्रिंग इंटरपोल
स्ट्रिंग इंटरपोलेशन एक स्ट्रिंग स्ट्रिंग शाब्दिक के अंदर उनके मूल्यों को शामिल करके स्थिरांक, चर, शाब्दिक और भावों के मिश्रण से एक नया स्ट्रिंग मूल्य बनाने का एक तरीका है। अमृत स्ट्रिंग में एक चर का उपयोग करने के लिए स्ट्रिंग प्रक्षेप का समर्थन करता है, इसे लिखते समय, इसे घुंघराले ब्रेसिज़ के साथ लपेटें और घुंघराले ब्रेसिज़ के साथ प्रीपेन्ड करें'#' संकेत।
उदाहरण के लिए,
x = "Apocalypse"
y = "X-men #{x}"
IO.puts(y)
यह x का मान लेगा और इसे y में स्थानापन्न करेगा। उपरोक्त कोड निम्नलिखित परिणाम उत्पन्न करेगा -
X-men Apocalypse
स्ट्रिंग कॉनटेनटेशन
हम पिछले अध्यायों में स्ट्रिंग संघनन के उपयोग को देख चुके हैं। '<>' ऑपरेटर का उपयोग अमृत में तार को समतल करने के लिए किया जाता है। 2 तारों को जोड़ने के लिए,
x = "Dark"
y = "Knight"
z = x <> " " <> y
IO.puts(z)
उपरोक्त कोड निम्नलिखित परिणाम उत्पन्न करता है -
Dark Knight
स्ट्रिंग लंबाई
स्ट्रिंग की लंबाई प्राप्त करने के लिए, हम इसका उपयोग करते हैं String.lengthसमारोह। स्ट्रिंग को एक पैरामीटर के रूप में पास करें और यह आपको अपना आकार दिखाएगा। उदाहरण के लिए,
IO.puts(String.length("Hello"))
कार्यक्रम से ऊपर चलने पर, यह निम्नलिखित परिणाम उत्पन्न करता है -
5
एक स्ट्रिंग उलट
किसी स्ट्रिंग को रिवर्स करने के लिए, इसे String.reverse फ़ंक्शन में पास करें। उदाहरण के लिए,
IO.puts(String.reverse("Elixir"))
उपरोक्त कार्यक्रम निम्नलिखित परिणाम उत्पन्न करता है -
rixilE
स्ट्रिंग तुलना
2 तारों की तुलना करने के लिए, हम == या === ऑपरेटरों का उपयोग कर सकते हैं। उदाहरण के लिए,
var_1 = "Hello world"
var_2 = "Hello Elixir"
if var_1 === var_2 do
IO.puts("#{var_1} and #{var_2} are the same")
else
IO.puts("#{var_1} and #{var_2} are not the same")
end
उपरोक्त कार्यक्रम निम्नलिखित परिणाम उत्पन्न करता है -
Hello world and Hello elixir are not the same.
स्ट्रिंग मिलान
हमने पहले ही = ~ स्ट्रिंग मैच ऑपरेटर का उपयोग देखा है। यह जांचने के लिए कि क्या एक स्ट्रिंग एक रेग्ज से मेल खाता है, हम स्ट्रिंग मिलान ऑपरेटर या स्ट्रिंगरमैच का भी उपयोग कर सकते हैं? समारोह। उदाहरण के लिए,
IO.puts(String.match?("foo", ~r/foo/))
IO.puts(String.match?("bar", ~r/foo/))
उपरोक्त कार्यक्रम निम्नलिखित परिणाम उत्पन्न करता है -
true
false
यह भी = ~ ऑपरेटर का उपयोग करके प्राप्त किया जा सकता है। उदाहरण के लिए,
IO.puts("foo" =~ ~r/foo/)
उपरोक्त कार्यक्रम निम्नलिखित परिणाम उत्पन्न करता है -
true
स्ट्रिंग फ़ंक्शंस
अमृत तार से संबंधित कार्यों की एक बड़ी संख्या का समर्थन करता है, सबसे अधिक उपयोग किए जाने वाले कुछ निम्न तालिका में सूचीबद्ध हैं।
अनु क्रमांक। | कार्य और इसका उद्देश्य |
---|---|
1 | at(string, position) दिए गए utf8 स्ट्रिंग की स्थिति में ग्रेपैम लौटाता है। यदि स्थिति स्ट्रिंग की लंबाई से अधिक है, तो यह शून्य देता है |
2 | capitalize(string) दिए गए स्ट्रिंग में पहले वर्ण को अपरकेस और शेष को निचले हिस्से में परिवर्तित करता है |
3 | contains?(string, contents) जाँच करता है कि स्ट्रिंग में दी गई कोई सामग्री है या नहीं |
4 | downcase(string) दिए गए स्ट्रिंग में सभी वर्णों को लोअरकेस में कनवर्ट करता है |
5 | ends_with?(string, suffixes) अगर स्ट्रिंग दी गई किसी भी प्रत्यय के साथ समाप्त हो जाती है, तो सच है |
6 | first(string) Utf8 स्ट्रिंग से पहला ग्रेपैम लौटाता है, अगर स्ट्रिंग खाली है तो nil |
7 | last(string) Utf8 स्ट्रिंग से अंतिम ग्रेपैम लौटाता है, यदि स्ट्रिंग खाली है तो शून्य करें |
8 | replace(subject, pattern, replacement, options \\ []) प्रतिस्थापन के साथ विषय में पैटर्न की घटनाओं को प्रतिस्थापित करके बनाया गया एक नया स्ट्रिंग देता है |
9 | slice(string, start, len) ऑफसेट प्रारंभ और लंबाई लेन पर शुरू करने वाला एक विकल्प है |
10 | split(string) प्रमुख और अनुगामी व्हाट्सएप की अनदेखी के साथ प्रत्येक यूनिकोड व्हाट्सएप घटना पर सबस्ट्रिंग में एक स्ट्रिंग को विभाजित करता है। व्हाट्सएप के समूहों को एक ही घटना के रूप में माना जाता है। विभाजन न टूटने वाले व्हाट्सएप पर नहीं होता है |
1 1 | upcase(string) दिए गए स्ट्रिंग के सभी वर्णों को अपरकेस में परिवर्तित करता है |
बाइनरी
एक बाइनरी सिर्फ बाइट्स का एक क्रम है। बायनेरिज़ का उपयोग करके परिभाषित किया गया है<< >>। उदाहरण के लिए:
<< 0, 1, 2, 3 >>
बेशक, उन बाइट्स को किसी भी तरह से व्यवस्थित किया जा सकता है, यहां तक कि एक अनुक्रम में जो उन्हें एक वैध स्ट्रिंग नहीं बनाता है। उदाहरण के लिए,
<< 239, 191, 191 >>
स्ट्रिंग्स भी बायनेरिज़ हैं। और स्ट्रिंग संघनन ऑपरेटर<> वास्तव में एक द्विआधारी संघनन ऑपरेटर है:
IO.puts(<< 0, 1 >> <> << 2, 3 >>)
उपरोक्त कोड निम्नलिखित परिणाम उत्पन्न करता है -
<< 0, 1, 2, 3 >>
Ł वर्ण नोट करें। चूंकि यह utf-8 एन्कोडेड है, इसलिए यह कैरेक्टर रिप्रेजेंटेशन 2 बाइट्स लेता है।
चूंकि बाइनरी में प्रस्तुत प्रत्येक संख्या का अर्थ एक बाइट है, जब यह मान 255 से ऊपर जाता है, तो इसे काट दिया जाता है। इसे रोकने के लिए, हम आकार संशोधक का उपयोग यह निर्दिष्ट करने के लिए करते हैं कि हम उस नंबर को कितने बिट्स लेना चाहते हैं। उदाहरण के लिए -
IO.puts(<< 256 >>) # truncated, it'll print << 0 >>
IO.puts(<< 256 :: size(16) >>) #Takes 16 bits/2 bytes, will print << 1, 0 >>
उपरोक्त कार्यक्रम निम्नलिखित परिणाम उत्पन्न करेगा -
<< 0 >>
<< 1, 0 >>
हम utf8 संशोधक का उपयोग भी कर सकते हैं, यदि कोई वर्ण कोड बिंदु है, तो इसे आउटपुट में उत्पादित किया जाएगा; और बाइट्स -
IO.puts(<< 256 :: utf8 >>)
उपरोक्त कार्यक्रम निम्नलिखित परिणाम उत्पन्न करता है -
Ā
हमारे पास एक फ़ंक्शन भी है जिसे कहा जाता है is_binaryयह जाँचता है कि क्या दिया गया चर बाइनरी है। ध्यान दें कि केवल चर जो 8 बिट के गुणक के रूप में संग्रहीत होते हैं, वे बायनेरी होते हैं।
Bitstrings
यदि हम आकार संशोधक का उपयोग करके एक द्विआधारी को परिभाषित करते हैं और इसे एक मान देते हैं जो 8 से अधिक नहीं है, तो हम बाइनरी के बजाय बिटस्ट्रिंग के साथ समाप्त होते हैं। उदाहरण के लिए,
bs = << 1 :: size(1) >>
IO.puts(bs)
IO.puts(is_binary(bs))
IO.puts(is_bitstring(bs))
उपरोक्त कार्यक्रम निम्नलिखित परिणाम उत्पन्न करता है -
<< 1::size(1) >>
false
true
इसका मतलब है कि चर bsएक बाइनरी नहीं है, बल्कि एक बिटस्ट्रिंग है। हम यह भी कह सकते हैं कि एक बाइनरी एक बिटस्ट्रिंग है जहां बिट्स की संख्या 8 से विभाज्य है। पैटर्न मिलान मिलान बायनेरिज़ के साथ-साथ बिटस्ट्रिंग्स पर भी उसी तरह काम करता है।