LISP - स्ट्रिंग्स

आम लिस्प में स्ट्रिंग्स वैक्टर हैं, यानी, एक आयामी चरित्र के सरणी।

स्ट्रिंग शाब्दिक दोहरे उद्धरण चिह्नों में संलग्न हैं। चरित्र सेट द्वारा समर्थित किसी भी चरित्र को डबल उद्धरण वर्ण (") और एस्केप वर्ण (\) को छोड़कर एक स्ट्रिंग बनाने के लिए दोहरे उद्धरणों के भीतर संलग्न किया जा सकता है। हालांकि, आप इन्हें बैकस्लैश (\) के साथ भागने से शामिल कर सकते हैं।

उदाहरण

Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।

(write-line "Hello World")
(write-line "Welcome to Tutorials Point")

;escaping the double quote character
(write-line "Welcome to \"Tutorials Point\"")

जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -

Hello World
Welcome to Tutorials Point
Welcome to "Tutorials Point"

स्ट्रिंग तुलनात्मक कार्य

संख्यात्मक तुलना फ़ंक्शंस और ऑपरेटर, जैसे, <और> स्ट्रिंग्स पर काम नहीं करते हैं। सामान्य LISP आपके कोड में तार की तुलना करने के लिए अन्य दो कार्य प्रदान करता है। एक सेट केस-संवेदी है और दूसरा केस-असंवेदनशील।

निम्न तालिका कार्य प्रदान करती है -

केस सेंसिटिव फंक्शंस केस-असंवेदनशील कार्य विवरण
स्ट्रिंग = स्ट्रिंग-बराबर जाँच करता है कि क्या ऑपरेंड के मान सभी समान हैं या नहीं, यदि हाँ तो स्थिति सच हो जाती है।
स्ट्रिंग / = स्ट्रिंग-नहीं-बराबर जाँच करता है कि क्या संचालकों के मूल्य अलग-अलग हैं या नहीं, यदि मान समान नहीं हैं तो स्थिति सत्य हो जाती है।
स्ट्रिंग < स्ट्रिंग-lessp जाँच करता है कि क्या ऑपरेंड्स का मान नीरस रूप से कम हो रहा है।
स्ट्रिंग> स्ट्रिंग-greaterp जाँच करता है कि क्या ऑपरेंड का मान नीरस रूप से बढ़ रहा है।
स्ट्रिंग <= स्ट्रिंग-नहीं-greaterp जाँच करता है कि क्या किसी बाएँ संकार्य का मान अगले दाहिने संकार्य के मान से अधिक या उसके बराबर है, यदि हाँ तो स्थिति सत्य हो जाती है।
स्ट्रिंग> = स्ट्रिंग-नहीं-lessp जाँच करता है कि क्या किसी भी बाएं ऑपरेंड का मूल्य उसके सही ऑपरेंड के मूल्य से कम या उसके बराबर है, यदि हाँ, तो स्थिति सच हो जाती है।

उदाहरण

Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।

; case-sensitive comparison
(write (string= "this is test" "This is test"))
(terpri)
(write (string> "this is test" "This is test"))
(terpri)
(write (string< "this is test" "This is test"))
(terpri)

;case-insensitive comparision
(write (string-equal "this is test" "This is test"))
(terpri)
(write (string-greaterp "this is test" "This is test"))
(terpri)
(write (string-lessp "this is test" "This is test"))
(terpri)

;checking non-equal
(write (string/= "this is test" "this is Test"))
(terpri)
(write (string-not-equal "this is test" "This is test"))
(terpri)
(write (string/= "lisp" "lisping"))
(terpri)
(write (string/= "decent" "decency"))

जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -

NIL
0
NIL
T
NIL
NIL
8
NIL
4
5

केस कंट्रोलिंग फ़ंक्शंस

निम्न तालिका कार्य नियंत्रण के मामले का वर्णन करती है -

अनु क्रमांक। समारोह विवरण
1

string-upcase

स्ट्रिंग को ऊपरी मामले में परिवर्तित करता है

2

string-downcase

स्ट्रिंग को निचले मामले में परिवर्तित करता है

3

string-capitalize

प्रत्येक शब्द को स्ट्रिंग में कैपिटल करता है

उदाहरण

Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।

(write-line (string-upcase "a big hello from tutorials point"))
(write-line (string-capitalize "a big hello from tutorials point"))

जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -

A BIG HELLO FROM TUTORIALS POINT
A Big Hello From Tutorials Point

स्ट्रिमिंग स्ट्रिंग्स

निम्न तालिका स्ट्रिंग ट्रिमिंग कार्यों का वर्णन करती है -

अनु क्रमांक। समारोह विवरण
1

string-trim

यह पहले तर्क के रूप में एक स्ट्रिंग (अक्षर) और दूसरे तर्क के रूप में एक स्ट्रिंग लेता है और एक विकल्प देता है, जहां पहले तर्क में सभी वर्ण तर्क स्ट्रिंग से हटा दिए जाते हैं।

2

String-left-trim

यह पहले तर्क के रूप में एक स्ट्रिंग (अक्षर) और दूसरे तर्क के रूप में एक स्ट्रिंग लेता है और एक विकल्प देता है जहां पहले तर्क में मौजूद सभी वर्ण तर्क स्ट्रिंग की शुरुआत से हटा दिए जाते हैं।

3

String-right-trim

यह पहले तर्क के रूप में एक स्ट्रिंग चरित्र (एस) और दूसरे तर्क के रूप में एक स्ट्रिंग लेता है और एक विकल्प देता है जहां पहले तर्क में मौजूद सभी वर्ण तर्क स्ट्रिंग के अंत से हटा दिए जाते हैं।

उदाहरण

Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।

(write-line (string-trim " " "   a big hello from tutorials point   "))
(write-line (string-left-trim " " "   a big hello from tutorials point   "))
(write-line (string-right-trim " " "   a big hello from tutorials point   "))
(write-line (string-trim " a" "   a big hello from tutorials point   "))

जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -

a big hello from tutorials point
a big hello from tutorials point   
   a big hello from tutorials point
big hello from tutorials point

अन्य स्ट्रिंग फ़ंक्शंस

LISP में स्ट्रिंग्स सरणियाँ हैं और इस प्रकार अनुक्रम भी हैं। हम आने वाले ट्यूटोरियल में इन डेटा प्रकारों को कवर करेंगे। सभी कार्य जो सरणियों और अनुक्रमों पर लागू होते हैं, वे स्ट्रिंग्स पर भी लागू होते हैं। हालांकि, हम विभिन्न उदाहरणों का उपयोग करके कुछ सामान्य रूप से उपयोग किए जाने वाले कार्यों का प्रदर्शन करेंगे।

लंबाई की गणना

length फ़ंक्शन एक स्ट्रिंग की लंबाई की गणना करता है।

उप-स्ट्रिंग निकालना

subseq फ़ंक्शन एक विशेष इंडेक्स पर शुरू होने और एक विशेष एंडिंग इंडेक्स या स्ट्रिंग के अंत तक जारी रखने के लिए एक उप-स्ट्रिंग (एक स्ट्रिंग भी एक अनुक्रम है) देता है।

स्ट्रिंग में कैरेक्टर एक्सेस करना

char फ़ंक्शन एक स्ट्रिंग के व्यक्तिगत पात्रों तक पहुंचने की अनुमति देता है।

Example

Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।

(write (length "Hello World"))
(terpri)
(write-line (subseq "Hello World" 6))
(write (char "Hello World" 6))

जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -

11
World
#\W

स्ट्रिंग्स की छंटाई और विलय

sortफ़ंक्शन एक स्ट्रिंग को सॉर्ट करने की अनुमति देता है। यह एक अनुक्रम (वेक्टर या स्ट्रिंग) और एक दो-तर्क विधेय करता है और अनुक्रम का एक क्रमबद्ध संस्करण लौटाता है।

merge फ़ंक्शन दो अनुक्रमों और एक विधेय को लेता है और एक अनुक्रम को दो अनुक्रमों को विलय करके उत्पादित करता है, जो कि विधेय के अनुसार है।

Example

Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।

;sorting the strings
(write (sort (vector "Amal" "Akbar" "Anthony") #'string<))
(terpri)

;merging the strings
(write (merge 'vector (vector "Rishi" "Zara" "Priyanka") 
   (vector "Anju" "Anuj" "Avni") #'string<))

जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -

#("Akbar" "Amal" "Anthony")
#("Anju" "Anuj" "Avni" "Rishi" "Zara" "Priyanka")

एक स्ट्रिंग उलट

reverse फ़ंक्शन एक स्ट्रिंग को उलट देता है।

उदाहरण के लिए, main.lisp नाम से एक नया स्रोत कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।

(write-line (reverse "Are we not drawn onward, we few, drawn onward to new era"))

जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -

are wen ot drawno nward ,wef ew ,drawno nward ton ew erA

कॉनटेटनेटिंग स्ट्रिंग्स

समतलन समारोह दो तारों को समेटता है। यह सामान्य अनुक्रम फ़ंक्शन है और आपको पहले तर्क के रूप में परिणाम प्रकार प्रदान करना होगा।

उदाहरण के लिए, main.lisp नाम से एक नया स्रोत कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।

(write-line (concatenate 'string "Are we not drawn onward, " "we few, drawn onward to new era"))

जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -

Are we not drawn onward, we few, drawn onward to new era