डी प्रोग्रामिंग - स्ट्रिंग्स
D दो प्रकार के स्ट्रिंग निरूपण प्रदान करता है -
- चरित्र सरणी
- कोर भाषा स्ट्रिंग
चरित्र सरणी
हम नीचे दिखाए गए अनुसार दो रूपों में से एक में चरित्र सरणी का प्रतिनिधित्व कर सकते हैं। पहला रूप सीधे आकार प्रदान करता है और दूसरा रूप दुपट्टा विधि का उपयोग करता है जो "गुड मॉर्निंग" स्ट्रिंग की एक लिखने योग्य प्रतिलिपि बनाता है।
char[9] greeting1 = "Hello all";
char[] greeting2 = "Good morning".dup;
उदाहरण
उपरोक्त सरल चरित्र सरणी रूपों का उपयोग करके यहां एक सरल उदाहरण दिया गया है।
import std.stdio;
void main(string[] args) {
char[9] greeting1 = "Hello all";
writefln("%s",greeting1);
char[] greeting2 = "Good morning".dup;
writefln("%s",greeting2);
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नानुसार परिणाम उत्पन्न करता है -
Hello all
Good morning
कोर भाषा स्ट्रिंग
स्ट्रिंग्स अंतर्निहित डी की मूल भाषा में हैं। ये तार ऊपर दिखाए गए वर्ण सरणी के साथ परस्पर जुड़े हुए हैं। निम्नलिखित उदाहरण एक साधारण स्ट्रिंग प्रतिनिधित्व दर्शाता है।
string greeting1 = "Hello all";
उदाहरण
import std.stdio;
void main(string[] args) {
string greeting1 = "Hello all";
writefln("%s",greeting1);
char[] greeting2 = "Good morning".dup;
writefln("%s",greeting2);
string greeting3 = greeting1;
writefln("%s",greeting3);
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नानुसार परिणाम उत्पन्न करता है -
Hello all
Good morning
Hello all
स्ट्रिंग कॉनटेनटेशन
डी प्रोग्रामिंग में स्ट्रिंग संघटन टिल्ड (~) प्रतीक का उपयोग करता है।
उदाहरण
import std.stdio;
void main(string[] args) {
string greeting1 = "Good";
char[] greeting2 = "morning".dup;
char[] greeting3 = greeting1~" "~greeting2;
writefln("%s",greeting3);
string greeting4 = "morning";
string greeting5 = greeting1~" "~greeting4;
writefln("%s",greeting5);
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नानुसार परिणाम उत्पन्न करता है -
Good morning
Good morning
स्ट्रिंग की लंबाई
बाइट्स में स्ट्रिंग की लंबाई को लंबाई में कटौती की मदद से पुनः प्राप्त किया जा सकता है।
उदाहरण
import std.stdio;
void main(string[] args) {
string greeting1 = "Good";
writefln("Length of string greeting1 is %d",greeting1.length);
char[] greeting2 = "morning".dup;
writefln("Length of string greeting2 is %d",greeting2.length);
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Length of string greeting1 is 4
Length of string greeting2 is 7
स्ट्रिंग तुलना
डी प्रोग्रामिंग में स्ट्रिंग तुलना काफी आसान है। आप स्ट्रिंग तुलना के लिए ==, <, और> ऑपरेटरों का उपयोग कर सकते हैं।
उदाहरण
import std.stdio;
void main() {
string s1 = "Hello";
string s2 = "World";
string s3 = "World";
if (s2 == s3) {
writeln("s2: ",s2," and S3: ",s3, " are the same!");
}
if (s1 < s2) {
writeln("'", s1, "' comes before '", s2, "'.");
} else {
writeln("'", s2, "' comes before '", s1, "'.");
}
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नानुसार परिणाम उत्पन्न करता है -
s2: World and S3: World are the same!
'Hello' comes before 'World'.
स्ट्रिंग्स की जगह
हम स्ट्रिंग का उपयोग करके स्ट्रिंग को बदल सकते हैं []।
उदाहरण
import std.stdio;
import std.string;
void main() {
char[] s1 = "hello world ".dup;
char[] s2 = "sample".dup;
s1[6..12] = s2[0..6];
writeln(s1);
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नानुसार परिणाम उत्पन्न करता है -
hello sample
सूचकांक के तरीके
इंडेक्सऑफ और लास्टइंडेक्सऑफ सहित स्ट्रिंग में एक विकल्प के स्थान के लिए सूचकांक विधियों को निम्नलिखित उदाहरण में समझाया गया है।
उदाहरण
import std.stdio;
import std.string;
void main() {
char[] s1 = "hello World ".dup;
writeln("indexOf of llo in hello is ",std.string.indexOf(s1,"llo"));
writeln(s1);
writeln("lastIndexOf of O in hello is " ,std.string.lastIndexOf(s1,"O",CaseSensitive.no));
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
indexOf.of llo in hello is 2
hello World
lastIndexOf of O in hello is 7
मामलों को संभालना
मामलों को बदलने के लिए उपयोग किए जाने वाले तरीके निम्नलिखित उदाहरण में दिखाए गए हैं।
उदाहरण
import std.stdio;
import std.string;
void main() {
char[] s1 = "hello World ".dup;
writeln("Capitalized string of s1 is ",capitalize(s1));
writeln("Uppercase string of s1 is ",toUpper(s1));
writeln("Lowercase string of s1 is ",toLower(s1));
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Capitalized string of s1 is Hello world
Uppercase string of s1 is HELLO WORLD
Lowercase string of s1 is hello world
वर्णों पर प्रतिबंध
स्ट्रिंग में वर्णों को पुनर्स्थापित करना निम्न उदाहरण में दिखाया गया है।
उदाहरण
import std.stdio;
import std.string;
void main() {
string s = "H123Hello1";
string result = munch(s, "0123456789H");
writeln("Restrict trailing characters:",result);
result = squeeze(s, "0123456789H");
writeln("Restrict leading characters:",result);
s = " Hello World ";
writeln("Stripping leading and trailing whitespace:",strip(s));
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Restrict trailing characters:H123H
Restrict leading characters:ello1
Stripping leading and trailing whitespace:Hello World