अमृत ​​- तार

एलिक्जिर में स्ट्रिंग्स को दोहरे उद्धरण चिह्नों के बीच डाला गया है, और वे 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 से विभाज्य है। पैटर्न मिलान मिलान बायनेरिज़ के साथ-साथ बिटस्ट्रिंग्स पर भी उसी तरह काम करता है।