रूबी - स्ट्रिंग्स

रूबी में एक स्ट्रिंग ऑब्जेक्ट एक या एक से अधिक बाइट्स के एक मनमाना अनुक्रम को धारण करता है, जो आमतौर पर मानव भाषा का प्रतिनिधित्व करने वाले पात्रों का प्रतिनिधित्व करता है।

सबसे सरल स्ट्रिंग शाब्दिक एकल उद्धरण (एपोस्ट्रोफ चरित्र) में संलग्न हैं। उद्धरण चिह्नों के भीतर का पाठ स्ट्रिंग का मूल्य है -

'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"]