रूबी - स्ट्रिंग्स
रूबी में एक स्ट्रिंग ऑब्जेक्ट एक या एक से अधिक बाइट्स के एक मनमाना अनुक्रम को धारण करता है, जो आमतौर पर मानव भाषा का प्रतिनिधित्व करने वाले पात्रों का प्रतिनिधित्व करता है।
सबसे सरल स्ट्रिंग शाब्दिक एकल उद्धरण (एपोस्ट्रोफ चरित्र) में संलग्न हैं। उद्धरण चिह्नों के भीतर का पाठ स्ट्रिंग का मूल्य है -
'This is a simple Ruby string literal'
यदि आपको एक एकल-उद्धृत स्ट्रिंग शाब्दिक के भीतर एक एपॉस्ट्रॉफ़ रखने की आवश्यकता है, तो इसे बैकस्लैश के साथ पूर्ववर्ती करें, ताकि रूबी दुभाषिया यह न सोचें कि यह स्ट्रिंग को समाप्त करता है -
'Won\'t you read O\'Reilly\'s book?'
बैकस्लैश एक और बैकस्लैश से बचने के लिए भी काम करता है, ताकि दूसरा बैकस्लैश खुद को एक एस्केप चरित्र के रूप में व्याख्या न करे।
रूबी की स्ट्रिंग-संबंधी विशेषताएं निम्नलिखित हैं।
अभिव्यक्ति प्रतिस्थापन
अभिव्यक्ति प्रतिस्थापन # {और} का उपयोग करके स्ट्रिंग में किसी भी रूबी अभिव्यक्ति के मूल्य को एम्बेड करने का एक साधन है -
#!/usr/bin/ruby
x, y, z = 12, 36, 72
puts "The value of x is #{ x }."
puts "The sum of x and y is #{ x + y }."
puts "The average was #{ (x + y + z)/3 }."
यह निम्नलिखित परिणाम का उत्पादन करेगा -
The value of x is 12.
The sum of x and y is 48.
The average was 40.
सामान्य सीमांकित स्ट्रिंग्स
सामान्य सीमांकित स्ट्रिंग्स के साथ, आप मिलान के एक जोड़े के अंदर स्ट्रिंग्स बना सकते हैं, हालांकि मनमाने ढंग से सीमांकन के पात्र, जैसे ?, (,, {, <, आदि), एक प्रतिशत चरित्र (%) से पहले, क्यू, क्यू, और एक्स में विशेष वर्ण हैं। सामान्य सीमांकित तार हो सकते हैं -
%{Ruby is fun.} equivalent to "Ruby is fun."
%Q{ Ruby is fun. } equivalent to " Ruby is fun. "
%q[Ruby is fun.] equivalent to a single-quoted string
%x!ls! equivalent to back tick command output `ls`
वर्ण से बचो
NOTE- एक डबल-उद्धृत स्ट्रिंग में, एक एस्केप चरित्र व्याख्या की गई है; एकल-उद्धृत स्ट्रिंग में, एक एस्केप चरित्र संरक्षित है।
बैकस्लैश नोटेशन | षोडश चरित्र | विवरण |
---|---|---|
\ए | 0x07 | बेल या सतर्क |
\ b | 0x08 | बैकस्पेस |
\ cx | नियंत्रण एक्स | |
\ Cx | नियंत्रण एक्स | |
\इ | 0x1b | पलायन |
\ च | 0x0c | फ़ीड बनाएं |
\ एम \ Cx | मेटा-नियंत्रण-x | |
\ n | 0x0A | नई पंक्ति |
\ NNN | ऑक्टल नोटेशन, जहां n सीमा 0.7 में है | |
\ r | 0x0d | कैरिज रिटर्न |
\ रों | 0x20 | अंतरिक्ष |
\ t | 0x09 | टैब |
\ v | 0x0b | लंबवत टैब |
\एक्स | चरित्र x | |
\ xnn | हेक्साडेसिमल नोटेशन, जहां n 0.9, एफआर, या एएफ रेंज में है |
अक्षरों को सांकेतिक अक्षरों में बदलना
रूबी के लिए निर्धारित डिफ़ॉल्ट चरित्र ASCII है, जिसके पात्रों को एकल बाइट्स द्वारा दर्शाया जा सकता है। यदि आप UTF-8, या किसी अन्य आधुनिक वर्ण सेट का उपयोग करते हैं, तो वर्णों को एक से चार बाइट्स में दर्शाया जा सकता है।
आप इस तरह से अपने कार्यक्रम की शुरुआत में $ KCODE का उपयोग करके अपने चरित्र सेट को बदल सकते हैं -
$KCODE = 'u'
अनु क्रमांक। | कोड और विवरण |
---|---|
1 | a ASCII (समान नहीं)। यह डिफ़ॉल्ट है। |
2 | e ईयूसी। |
3 | n कोई नहीं (ASCII के समान)। |
4 | u UTF-8। |
स्ट्रिंग में निर्मित तरीके
हमें स्ट्रिंग पद्धति को कॉल करने के लिए स्ट्रिंग ऑब्जेक्ट का एक उदाहरण होना चाहिए। निम्नलिखित स्ट्रिंग वस्तु का एक उदाहरण बनाने का तरीका है -
new [String.new(str = "")]
यह एक नया स्ट्रिंग ऑब्जेक्ट लौटाएगा जिसमें str की एक प्रति होगी । अब, str ऑब्जेक्ट का उपयोग करके , हम सभी किसी भी उपलब्ध इंस्टेंस विधियों का उपयोग कर सकते हैं। उदाहरण के लिए -
#!/usr/bin/ruby
myStr = String.new("THIS IS TEST")
foo = myStr.downcase
puts "#{foo}"
यह निम्नलिखित परिणाम का उत्पादन करेगा -
this is test
अनु क्रमांक। | तरीके और विवरण |
---|---|
1 | str % arg एक प्रारूप विनिर्देशन का उपयोग करके एक स्ट्रिंग को प्रारूपित करता है। अगर यह एक से अधिक प्रतिस्थापन है तो arg एक सरणी होना चाहिए। प्रारूप विनिर्देश के बारे में जानकारी के लिए, "कर्नेल मॉड्यूल" के तहत स्प्रिंट देखें। |
2 | str * integer एक नया स्ट्रिंग देता है जिसमें पूर्णांक बार str होता है। दूसरे शब्दों में, str को बार-बार पूर्णांक imes कहा जाता है। |
3 | str + other_str Concatenates other_str को str। |
4 | str << obj किसी वस्तु को str से समेटता है। यदि ऑब्जेक्ट 0.255 सीमा में एक Fixnum है, तो इसे एक वर्ण में बदल दिया जाता है। इसकी तुलना समास से करें। |
5 | str <=> other_str अन्य_स्ट्र के साथ तुलना करता है, -1 (से कम), 0 (बराबर), या 1 (अधिक से अधिक) लौटाता है। तुलना केस-संवेदी है। |
6 | str == obj समानता के लिए टेस्ट और ओबीजी। यदि ओब्ज स्ट्रिंग नहीं है, तो गलत है; रिटर्न सही है अगर str <=> obj रिटर्न 0। |
7 | str =~ obj एक रेगुलर एक्सप्रेशन पैटर्न ओबज के खिलाफ मैच मैच वह स्थिति लौटाता है जहाँ मैच शुरू होता है; अन्यथा, गलत है। |
8 | str.capitalize एक स्ट्रिंग को बड़ा करता है। |
9 | str.capitalize! पूंजी के रूप में भी, लेकिन परिवर्तन जगह में किए गए हैं। |
10 | str.casecmp तार के मामले-असंवेदनशील बनाता है। |
1 1 | str.center केंद्र एक स्ट्रिंग। |
12 | str.chomp स्ट्रिंग के अंत से रिकॉर्ड विभाजक ($ /), आमतौर पर \ n निकालता है। यदि कोई रिकॉर्ड विभाजक मौजूद नहीं है, तो कुछ भी नहीं करता है। |
13 | str.chomp! धूमधाम के रूप में भी, लेकिन जगह में परिवर्तन किए जाते हैं। |
14 | str.chop पिछले वर्ण को निकालता है। |
15 | str.chop! काट के रूप में भी, लेकिन परिवर्तन जगह में किए गए हैं। |
16 | str.concat(other_str) Concatenates other_str को str। |
17 | str.count(str, ...) वर्णों के एक या अधिक सेट गिना जाता है। यदि वर्णों का एक से अधिक सेट है, तो उन सेटों के प्रतिच्छेदन को गिनता है |
18 | str.crypt(other_str) एक-तरफ़ा क्रिप्टोग्राफ़िक हैश को str में लागू करता है। तर्क नमक स्ट्रिंग है, जो दो वर्ण लंबा होना चाहिए, रेंज में प्रत्येक वर्ण az, AZ, 0.9,। या /। |
19 | str.delete(other_str, ...) हटाए गए अपने तर्कों के प्रतिच्छेदन में सभी वर्णों के साथ str की एक प्रति लौटाता है। |
20 | str.delete!(other_str, ...) डिलीट के रूप में भी, लेकिन परिवर्तन जगह में किए गए हैं। |
21 | str.downcase लोअरकेस के साथ प्रतिस्थापित सभी अपरकेस अक्षरों के साथ str की एक प्रति लौटाता है। |
22 | str.downcase! नीचे की तरह ही, लेकिन जगह में बदलाव किए जाते हैं। |
23 | str.dump सभी गैर-वर्णों वाले वर्णों का एक संस्करण लौटाता है जिसे \ nnn संकेतन द्वारा प्रतिस्थापित किया जाता है और सभी विशेष वर्ण बच जाते हैं। |
24 | str.each(separator = $/) { |substr| block } विभाजित विभाजक के रूप में तर्क का उपयोग करते हुए स्प्लिट्स ($ / डिफ़ॉल्ट रूप से), आपूर्ति किए गए ब्लॉक के प्रत्येक विकल्प को पास करते हुए। |
25 | str.each_byte { |fixnum| block } प्रत्येक बाइट को ब्लॉक के ऊपर से गुजरता है, प्रत्येक बाइट को बाइट के दशमलव प्रतिनिधित्व के रूप में लौटाता है। |
26 | str.each_line(separator=$/) { |substr| block } विभाजित विभाजक के रूप में तर्क का उपयोग करते हुए स्प्लिट्स ($ / डिफ़ॉल्ट रूप से), आपूर्ति किए गए ब्लॉक के प्रत्येक विकल्प को पास करते हुए। |
27 | str.empty? सही है अगर str खाली है (शून्य लंबाई है)। |
28 | str.eql?(other) दो तार बराबर हैं यदि उनकी लंबाई और सामग्री समान है। |
29 | str.gsub(pattern, replacement) [or] str.gsub(pattern) { |match| block } प्रतिरूप या ब्लॉक के मूल्य के साथ प्रतिस्थापित पैटर्न की सभी घटनाओं के साथ str की एक प्रति लौटाता है। पैटर्न आमतौर पर एक Regexp होगा; यदि यह एक स्ट्रिंग है, तो कोई भी नियमित अभिव्यक्ति मेटाचैकर्स की व्याख्या नहीं की जाएगी (अर्थात, / \ d / एक अंक से मेल खाएगी, लेकिन 'd' एक बैकस्लैश से मेल खाएगी, जो 'd' से होगा) |
30 | str[fixnum] [or] str[fixnum,fixnum] [or] str[range] [or] str[regexp] [or] str[regexp, fixnum] [or] str[other_str] निम्नलिखित तर्कों का उपयोग करते हुए संदर्भ: एक फिक्सनम, एक वर्ण कोड देता है; दो फ़िक्नेम्स, एक ऑफसेट (पहली फ़िक्नुम) से शुरू होकर लंबाई (दूसरा फ़िक्नुम) तक पहुँचता है; रेंज, रेंज में एक सबरिंग लौटाता है; मिलान स्ट्रिंग का रेगेक्सपी रिटर्न भाग; फ़िक्नम के साथ रेगेक्सप, फ़िक्नम में मिलान किए गए डेटा; अन्य_स्ट्रस्ट अन्य_स्ट्रस्ट से मेल खाते हुए विकल्प हैं। एक नकारात्मक फिक्सनम स्ट्रिंग के अंत में शुरू होता है -1। |
31 | str[fixnum] = fixnum [or] str[fixnum] = new_str [or] str[fixnum, fixnum] = new_str [or] str[range] = aString [or] str[regexp] = new_str [or] str[regexp, fixnum] = new_str [or] str[other_str] = new_str ] एक स्ट्रिंग के सभी या भाग को बदलें (असाइन करें)। स्लाइस का पर्यायवाची !. |
32 | str.gsub!(pattern, replacement) [or] str.gsub!(pattern) { |match|block } स्ट्रिंग # gsub के प्रतिस्थापन को निष्पादित करता है, यदि कोई प्रतिस्थापन नहीं किया गया था, तो वापस लौटना या शून्य करना। |
33 | str.hash स्ट्रिंग की लंबाई और सामग्री के आधार पर एक हैश लौटाता है। |
34 | str.hex हेक्साडेसिमल अंकों की एक स्ट्रिंग (वैकल्पिक संकेत और एक वैकल्पिक 0x के साथ) के रूप में str से अग्रणी पात्रों का व्यवहार करता है और संबंधित संख्या देता है। शून्य त्रुटि पर दिया जाता है। |
35 | str.include? other_str [or] str.include? fixnum यदि स्ट्रिंग दिए गए अक्षर या वर्ण में सही है, तो लौटाता है। |
36 | str.index(substring [, offset]) [or] str.index(fixnum [, offset]) [or] str.index(regexp [, offset]) दिए गए सबस्ट्रिंग, वर्ण (फ़िक्नम), या पैटर्न (regexp) की पहली घटना के सूचकांक को वापस लौटाता है। न मिलने पर वापस कर देता है। यदि दूसरा पैरामीटर मौजूद है, तो यह खोज शुरू करने के लिए स्ट्रिंग में स्थिति निर्दिष्ट करता है। |
37 | str.insert(index, other_str) दिए गए इंडेक्स में कैरेक्टर से पहले other_str सम्मिलित करता है, str को संशोधित करता है। नकारात्मक सूचकांक स्ट्रिंग के अंत से गिने जाते हैं, और दिए गए वर्ण के बाद सम्मिलित होते हैं। आशय एक स्ट्रिंग सम्मिलित करना है ताकि यह दिए गए सूचकांक पर शुरू हो। |
38 | str.inspect विशेष वर्णों से बचकर, str का एक मुद्रण योग्य संस्करण देता है। |
39 | str.intern [or] str.to_sym यदि यह पहले से मौजूद नहीं था, तो प्रतीक बनाते हुए, str को इसी सिंबल पर लौटाता है। |
40 | str.length Str की लंबाई देता है। आकार की तुलना करें। |
41 | str.ljust(integer, padstr = ' ') यदि पूर्णांक लंबाई की लंबाई से अधिक है, तो लंबाई के बराबर पूर्णांक के साथ एक नया स्ट्रिंग लौटाता है, जो कि उचित है और पैडस्ट के साथ गद्देदार है; अन्यथा, लौट आता है। |
42 | str.lstrip हटाए गए प्रमुख व्हाट्सएप के साथ str की एक प्रति लौटाता है। |
43 | str.lstrip! कोई परिवर्तन नहीं किया गया था, तो वापस लौटने से प्रमुख व्हाट्सएप को हटा देता है। |
44 | str.match(pattern) एक Regexp के पैटर्न को परिवर्तित करता है (यदि यह पहले से ही एक नहीं है), तो str पर इसकी मैच विधि लागू करता है। |
45 | str.oct ऑक्टल अंकों की एक स्ट्रिंग के रूप में (एक वैकल्पिक संकेत के साथ) के प्रमुख पात्रों को मानता है और संबंधित संख्या देता है। रूपांतरण विफल होने पर 0 देता है। |
46 | str.replace(other_str) अन्य_स्ट्रस्ट में संबंधित मूल्यों के साथ स्ट्रिंग की सामग्री और दागीपन को प्रतिस्थापित करता है। |
47 | str.reverse उल्टे क्रम में str से वर्णों के साथ एक नया तार लौटाता है। |
48 | str.reverse! जगह-जगह उलटियां होती हैं। |
49 | str.rindex(substring [, fixnum]) [or] str.rindex(fixnum [, fixnum]) [or] str.rindex(regexp [, fixnum]) दिए गए सबस्ट्रिंग, वर्ण (फ़िक्नम), या पैटर्न (regexp) की अंतिम घटना के सूचकांक को वापस लौटाता है। न मिलने पर वापस कर देता है। यदि दूसरा पैरामीटर मौजूद है, तो यह खोज को समाप्त करने के लिए स्ट्रिंग में स्थिति निर्दिष्ट करता है। इस बिंदु से परे हटाने वालों पर विचार नहीं किया जाएगा। |
50। | str.rjust(integer, padstr = ' ') यदि पूर्णांक लंबाई की लंबाई से अधिक है, तो लंबाई के पूर्णांक के साथ लंबाई पूर्णांक का नया स्ट्रिंग लौटाता है और पैडस्ट्र के साथ गद्देदार होता है; अन्यथा, लौट आता है। |
51 | str.rstrip हटाए गए व्हाट्सएप के साथ स्ट्रोक की एक प्रति लौटाता है। |
52 | str.rstrip! कोई परिवर्तन नहीं किया गया था, तो वापस लौटने से, पीछे से व्हॉट्सएप का निशान हटाता है। |
53 | str.scan(pattern) [or] str.scan(pattern) { |match, ...| block } दोनों स्ट्रेट के माध्यम से पुनरावृति बनाते हैं, पैटर्न से मेल खाते हैं (जो एक Regexp या एक स्ट्रिंग हो सकता है)। प्रत्येक मैच के लिए, एक परिणाम उत्पन्न होता है और या तो परिणाम सरणी में जोड़ा जाता है या ब्लॉक में जाता है। यदि पैटर्न में कोई समूह नहीं है, तो प्रत्येक व्यक्तिगत परिणाम में मिलान स्ट्रिंग, $ & होता है। यदि पैटर्न में समूह होते हैं, तो प्रत्येक व्यक्तिगत परिणाम एक सरणी होता है जिसमें प्रति समूह एक प्रविष्टि होती है। |
54 | str.slice(fixnum) [or] str.slice(fixnum, fixnum) [or] str.slice(range) [or] str.slice(regexp) [or] str.slice(regexp, fixnum) [or] str.slice(other_str) See str[fixnum], etc. str.slice!(fixnum) [or] str.slice!(fixnum, fixnum) [or] str.slice!(range) [or] str.slice!(regexp) [or] str.slice!(other_str) निर्दिष्ट भाग को str से हटाता है, और हटाए गए भाग को वापस करता है। यदि फ़िक्नम लेने वाले फॉर्म एक IndexError बढ़ाएंगे यदि मूल्य सीमा से बाहर है; रेंज फॉर्म एक रेंजएयर उठाएगा, और रेगेक्सपी और स्ट्रिंग फॉर्म चुपचाप असाइनमेंट को अनदेखा कर देंगे। |
55 | str.split(pattern = $, [limit]) इन पदार्थों के एक सरणी को वापस करते हुए, एक सीमांकक के आधार पर सब्सट्रिंग्स में विभाजित होते हैं। यदि पैटर्न एक स्ट्रिंग है, तो स्ट्रेट को विभाजित करते समय इसकी सामग्री को सीमांकक के रूप में उपयोग किया जाता है। यदि पैटर्न एक ही स्थान है, तो व्हाट्सएप पर स्ट्रेट को विभाजित किया जाता है, जिसमें प्रमुख व्हाट्सएप और सन्निहित व्हाट्सएप के पात्रों को अनदेखा किया जाता है। यदि पैटर्न एक Regexp है, तो str को विभाजित किया जाता है जहां पैटर्न मैच करता है। जब भी पैटर्न एक शून्य-लंबाई वाली स्ट्रिंग से मेल खाता है, str व्यक्तिगत वर्णों में विभाजित होता है। यदि पैटर्न छोड़ा गया है, का मान$; is used. If $; nil है (जो कि डिफ़ॉल्ट है), str को व्हाट्सएप पर विभाजित किया जाता है जैसे कि `` निर्दिष्ट किए गए थे। यदि सीमा पैरामीटर को छोड़ दिया जाता है, तो ट्रेलिंग नल फ़ील्ड को दबा दिया जाता है। यदि सीमा एक सकारात्मक संख्या है, तो उस क्षेत्र की अधिकांश संख्या वापस आ जाएगी (यदि सीमा 1 है, तो संपूर्ण स्ट्रिंग को एक सरणी में केवल प्रविष्टि के रूप में लौटा दिया जाता है)। यदि ऋणात्मक है, तो लौटे हुए फ़ील्ड की संख्या की कोई सीमा नहीं है, और अनुगामी नल फ़ील्ड को दबाया नहीं जाता है। |
56 | str.squeeze([other_str]*) स्ट्रिंग # गिनती के लिए वर्णित प्रक्रिया का उपयोग करके अन्य_स्ट्राल पैरामीटर (ओं) से वर्णों का एक सेट बनाता है। एक नया स्ट्रिंग लौटाता है, जहां एक ही वर्ण के रन इस सेट में होते हैं जो एकल वर्ण द्वारा प्रतिस्थापित किए जाते हैं। यदि कोई तर्क नहीं दिया जाता है, तो समान वर्णों के सभी रन एकल वर्ण द्वारा प्रतिस्थापित किए जाते हैं। |
57 | str.squeeze!([other_str]*) यदि कोई परिवर्तन नहीं किया गया था, तो जगह-जगह पर हमले हुए, या तो वापस लौट आए, या शून्य हो गए। |
58 | str.strip हटाई गई प्रमुख और अनुगामी व्हाट्सएप के साथ str की एक प्रति लौटाता है। |
59 | str.strip! प्रमुख और अनुगामी व्हाट्सएप को दूर से हटाता है। रिटर्न nil अगर str बदल नहीं गया था। |
60 | str.sub(pattern, replacement) [or] str.sub(pattern) { |match| block } पैटर्न की पहली घटना के साथ स्ट्रोक की एक प्रति लौटाता है या तो प्रतिस्थापन या ब्लॉक के मूल्य के साथ प्रतिस्थापित किया जाता है। पैटर्न आमतौर पर एक Regexp होगा; अगर यह एक स्ट्रिंग है तो कोई नियमित अभिव्यक्ति मेटाचैकर की व्याख्या नहीं की जाएगी। |
61 | str.sub!(pattern, replacement) [or] str.sub!(pattern) { |match| block } स्ट्रिंग # उप के स्थानापन्न को निष्पादित करता है, यदि कोई प्रतिस्थापन नहीं किया गया है, तो वापस लौटना, या शून्य करना। |
62 | str.succ [or] str.next उत्तराधिकारी को लौट जाता है। |
63 | str.succ! [or] str.next! स्ट्रिंग # succ के बराबर, लेकिन जगह में रिसीवर को संशोधित करता है। |
64 | str.sum(n = 16) Str में वर्णों का एक मूल n-बिट चेकसम लौटाता है, जहाँ n वैकल्पिक फिक्सनम पैरामीटर है, जो कि डिफ़ॉल्ट रूप से 16 है। परिणाम केवल str modulo 2n में प्रत्येक वर्ण के बाइनरी मान का योग है - 1. यह विशेष रूप से नहीं है अच्छा चेकसम। |
65 | str.swapcase अपरकेस वर्णमाला के साथ str की एक प्रति लौटाता है जिसे लोअरकेस में परिवर्तित किया जाता है और अपरकेस अक्षरों को परिवर्तित किया जाता है। |
66 | str.swapcase! स्ट्रिंग # स्वैप के समतुल्य, लेकिन जगह में रिसीवर को संशोधित करता है, वापस लौट रहा है, या यदि कोई परिवर्तन नहीं किया गया है तो शून्य। |
67 | str.to_f > फ़्लोटिंग-पॉइंट संख्या के रूप में str में अग्रणी वर्णों की व्याख्या करने का परिणाम देता है। किसी मान्य संख्या के अंत में पिछले वर्णों को अनदेखा कर दिया जाता है। यदि प्रारंभ के समय कोई मान्य संख्या नहीं है, तो 0.0 लौटा दी जाती है। यह विधि कभी भी अपवाद नहीं उठाती है। |
68 | str.to_i(base = 10) पूर्णांक आधार (बेस 2, 8, 10, या 16) के रूप में str में अग्रणी वर्णों की व्याख्या करने का परिणाम देता है। किसी मान्य संख्या के अंत में पिछले वर्णों को अनदेखा कर दिया जाता है। यदि प्रारंभ के प्रारंभ में कोई मान्य संख्या नहीं है, तो 0 लौटा दी जाती है। यह विधि कभी भी अपवाद नहीं उठाती है। |
69 | str.to_s [or] str.to_str रिसीवर लौटा देता है। |
70 | str.tr(from_str, to_str) In_str से वर्णों के साथ str की एक प्रति लौटाता है जो in_str के संगत वर्णों द्वारा प्रतिस्थापित की जाती है। यदि to_str from_str से छोटा है, तो यह अपने अंतिम वर्ण के साथ गद्देदार है। दोनों तार वर्णों की श्रेणियों को निरूपित करने के लिए c1.c2 संकेतन का उपयोग कर सकते हैं, और from_str एक ^ से शुरू हो सकता है, जो सूचीबद्ध किए गए को छोड़कर सभी वर्णों को दर्शाता है। |
71 | str.tr!(from_str, to_str) String # tr के समान नियमों का उपयोग करते हुए, स्थान में अनुवाद करता है। यदि कोई परिवर्तन नहीं किया गया था, तो रिटर्न str या nil है। |
72 | str.tr_s(from_str, to_str) स्ट्रिंग # tr के तहत वर्णित str की एक प्रतिलिपि संसाधित करता है, फिर उन क्षेत्रों में डुप्लिकेट वर्णों को निकालता है जो अनुवाद से प्रभावित थे। |
73 | str.tr_s!(from_str, to_str) यदि कोई परिवर्तन नहीं किया गया था, तो स्ट्रिंग # tr_s प्रसंस्करण को स्ट्रिंग पर लौटाता है, या वापस लौटाता है। |
74 | str.unpack(format) > स्ट्रिंग स्ट्रिंग (जिसमें बाइनरी डेटा हो सकता है) प्रारूप स्ट्रिंग के अनुसार, निकाले गए प्रत्येक मान की एक सरणी लौटाता है। प्रारूप स्ट्रिंग में एकल-वर्ण निर्देशों का एक क्रम होता है, जिसे सारणी 18 में संक्षेपित किया गया है। प्रत्येक निर्देश को एक संख्या द्वारा अनुसरण किया जा सकता है, इस निर्देश के साथ दोहराने के लिए समय की संख्या को दर्शाता है। एक तारांकन (*) शेष सभी तत्वों का उपयोग करेगा। निर्देश sSiIlL प्रत्येक को अंडरस्कोर (_) द्वारा निर्दिष्ट प्रकार के लिए अंतर्निहित प्लेटफ़ॉर्म के मूल आकार का उपयोग करने के लिए हो सकता है; अन्यथा, यह एक प्लेटफ़ॉर्म-स्वतंत्र सुसंगत आकार का उपयोग करता है। प्रारूप स्ट्रिंग में रिक्त स्थान की अनदेखी की जाती है। |
75 | str.upcase सभी छोटे अक्षरों के साथ str की एक प्रति को उनके अपरकेस समकक्षों के साथ बदल देता है। ऑपरेशन लोकल असंवेदनशील है। केवल a से z अक्षर प्रभावित होते हैं। |
76 | str.upcase! यदि परिवर्तन नहीं किए गए हैं, तो ऊपर लौटने के लिए str की सामग्री को बदल देता है। |
77 | str.upto(other_str) { |s| block } क्रमिक मूल्यों के माध्यम से Iterates, str पर शुरू होता है और अन्य_str समावेशी पर समाप्त होता है, ब्लॉक के बदले में प्रत्येक मूल्य को पारित करता है। प्रत्येक मान उत्पन्न करने के लिए स्ट्रिंग # succ विधि का उपयोग किया जाता है। |
स्ट्रिंग निर्देश unpack
आदेश | रिटर्न | विवरण |
---|---|---|
ए | तार | अनुगामी नल और रिक्त स्थान के साथ। |
ए | तार | स्ट्रिंग। |
ख | तार | प्रत्येक वर्ण से बिट्स निकालता है (सबसे महत्वपूर्ण बिट पहले)। |
ख | तार | प्रत्येक वर्ण से बिट्स निकालता है (कम से कम महत्वपूर्ण बिट पहले)। |
सी | Fixnum | एक वर्ण को एक अहस्ताक्षरित पूर्णांक के रूप में निकालता है। |
सी | Fixnum | किसी वर्ण को पूर्णांक के रूप में निकालता है। |
डी, डी | फ्लोट | देशी डबल के रूप में आकार (डबल) वर्ण मानते हैं। |
इ | फ्लोट | लिटिल बाइट क्रम में डबल के रूप में आकार (डबल) वर्णों का व्यवहार करता है। |
इ | फ्लोट | बिटेंडियन बाइट क्रम में फ्लोट के रूप में आकार (फ्लोट) पात्रों को व्यवहार करता है। |
एफ, एफ | फ्लोट | देशी फ्लोट के रूप में आकार (फ्लोट) वर्ण मानते हैं। |
जी | फ्लोट | नेटवर्क बाइट क्रम में डबल के रूप में आकार (डबल) वर्ण मानते हैं। |
जी | तार | नेटवर्क बाइट क्रम में फ्लोट के रूप में आकार (फ्लोट) वर्ण व्यवहार करता है। |
एच | तार | प्रत्येक वर्ण से हेक्स निबल्स निकालता है (सबसे महत्वपूर्ण बिट पहले) |
एच | तार | प्रत्येक चरित्र से हेक्स निबल्स निकालता है (कम से कम महत्वपूर्ण बिट पहले)। |
मैं | पूर्णांक | साइज़ोफ़ (इंट) (संशोधित द्वारा _) क्रमबद्ध वर्णों को एक अहस्ताक्षरित देशी पूर्णांक के रूप में मानता है। |
मैं | पूर्णांक | एक हस्ताक्षरित देशी पूर्णांक के रूप में आकार (int) (_ द्वारा संशोधित) क्रमिक वर्ण मानता है। |
एल | पूर्णांक | एक निरंकुश देशी लंबे पूर्णांक के रूप में चार (_ द्वारा संशोधित) क्रमिक वर्ण मानता है। |
एल | पूर्णांक | एक हस्ताक्षरित देशी लंबे पूर्णांक के रूप में चार (_ द्वारा संशोधित) क्रमिक वर्ण मानता है। |
म | तार | उद्धरित-मुद्रण योग्य। |
म | तार | Base64- एन्कोड। |
एन | पूर्णांक | नेटवर्क बाइट ऑर्डर में चार वर्णों को एक अहस्ताक्षरित लंबे समय तक मानता है। |
n | Fixnum | नेटवर्क बाइट ऑर्डर में दो अक्षरों को एक अहस्ताक्षरित लघु के रूप में मानता है। |
पी | तार | आकार सूचक (चार *) वर्णों को एक सूचक के रूप में मानते हैं, और संदर्भित स्थान से \ emph {len} वर्ण वापस करते हैं। |
पी | तार | एक अशक्त-समाप्त स्ट्रिंग के लिए सूचक के रूप में आकार (चार *) वर्णों का व्यवहार करता है। |
क्यू | पूर्णांक | आठ अक्षरों को एक अहस्ताक्षरित क्वाड शब्द (64 बिट्स) के रूप में मानता है। |
क्यू | पूर्णांक | आठ अक्षरों को एक हस्ताक्षरित क्वाड शब्द (64 बिट्स) के रूप में मानता है। |
रों | Fixnum | देशी बाइट क्रम में एक अहस्ताक्षरित लघु के रूप में दो (अलग-अलग अगर _ इस्तेमाल किए गए) क्रमिक अक्षरों को मानता है। |
रों | Fixnum | देशी बाइट क्रम में एक हस्ताक्षरित लघु के रूप में दो (अलग अगर _ इस्तेमाल किया गया) क्रमिक वर्णों का व्यवहार करता है। |
यू | पूर्णांक | अहस्ताक्षरित पूर्णांक के रूप में UTF-8 वर्ण। |
यू | तार | UU एन्कोड। |
वी | Fixnum | लिटिल-एंडियन बाइट ऑर्डर में चार वर्णों को एक अहस्ताक्षरित लंबे समय तक मानता है। |
v | Fixnum | लिटिल-एंडियन बाइट ऑर्डर में दो पात्रों को एक अहस्ताक्षरित लघु के रूप में मानता है। |
w | पूर्णांक | BER- संपीड़ित पूर्णांक। |
एक्स | एक पात्र को पीछे छोड़ता है। | |
एक्स | एक पात्र को छोड़ देता है। | |
जेड | तार | अनुगामी नल के साथ * पहले नल को हटा दिया गया। |
@ | लंबाई तर्क द्वारा दिए गए ऑफसेट को छोड़ देता है। |
उदाहरण
विभिन्न डेटा को अनपैक करने के लिए निम्न उदाहरण का प्रयास करें।
"abc \0\0abc \0\0".unpack('A6Z6') #=> ["abc", "abc "]
"abc \0\0".unpack('a3a3') #=> ["abc", " \000\000"]
"abc \0abc \0".unpack('Z*Z*') #=> ["abc ", "abc "]
"aa".unpack('b8B8') #=> ["10000110", "01100001"]
"aaa".unpack('h2H2c') #=> ["16", "61", 97]
"\xfe\xff\xfe\xff".unpack('sS') #=> [-2, 65534]
"now = 20is".unpack('M*') #=> ["now is"]
"whole".unpack('xax2aX2aX1aX2a') #=> ["h", "e", "l", "l", "o"]