लुआ - टेबल्स

परिचय

लुआ में उपलब्ध टेबल्स एकमात्र डेटा संरचना है जो विभिन्न प्रकारों जैसे सरणियों और शब्दकोशों को बनाने में हमारी मदद करती है। लुआ साहचर्य सरणियों का उपयोग करता है और जिसे न केवल संख्याओं के साथ अनुक्रमित किया जा सकता है, बल्कि शून्य के अलावा तार के साथ भी। टेबल्स का कोई निश्चित आकार नहीं है और यह हमारी जरूरत के आधार पर बढ़ सकता है।

लुआ संकुल के प्रतिनिधित्व सहित सभी अभ्यावेदन में तालिकाओं का उपयोग करता है जब हम एक पद्धति string.format तक पहुँचते हैं, तो इसका मतलब है, हम स्ट्रिंग पैकेज में उपलब्ध प्रारूप फ़ंक्शन तक पहुँच रहे हैं।

प्रतिनिधित्व और उपयोग

तालिकाओं को ऑब्जेक्ट कहा जाता है और वे न तो मान हैं और न ही चर। लुआ एक खाली तालिका बनाने के लिए एक कंस्ट्रक्टर अभिव्यक्ति {} का उपयोग करता है। यह ज्ञात है कि एक चर के बीच कोई निश्चित संबंध नहीं है जो तालिका और स्वयं तालिका का संदर्भ रखता है।

--sample table initialization
mytable = {}

--simple table value assignment
mytable[1]= "Lua"

--removing reference
mytable = nil

-- lua garbage collection will take care of releasing memory

जब हमारे पास एक मेज है a तत्वों के सेट के साथ और अगर हम इसे असाइन करते हैं b, दोनों a तथा bउसी मेमोरी का संदर्भ लें। बी के लिए अलग से कोई मेमोरी आवंटित नहीं की जाती है। जब एक को शून्य पर सेट किया जाता है, टेबल अभी भी बी तक पहुंच जाएगा। जब किसी तालिका का कोई संदर्भ नहीं होता है, तो लुआ में कचरा संग्रह फिर से उपयोग की जाने वाली इन अप्रतिबंधित स्मृति को बनाने के लिए सफाई की प्रक्रिया का ख्याल रखता है।

टेबल की उपर्युक्त विशेषताओं को समझाने के लिए एक उदाहरण नीचे दिखाया गया है।

-- Simple empty table
mytable = {}
print("Type of mytable is ",type(mytable))

mytable[1]= "Lua"
mytable["wow"] = "Tutorial"

print("mytable Element at index 1 is ", mytable[1])
print("mytable Element at index wow is ", mytable["wow"])

-- alternatetable and mytable refers to same table
alternatetable = mytable

print("alternatetable Element at index 1 is ", alternatetable[1])
print("alternatetable Element at index wow is ", alternatetable["wow"])

alternatetable["wow"] = "I changed it"

print("mytable Element at index wow is ", mytable["wow"])

-- only variable released and and not table
alternatetable = nil
print("alternatetable is ", alternatetable)

-- mytable is still accessible
print("mytable Element at index wow is ", mytable["wow"])

mytable = nil
print("mytable is ", mytable)

जब हम उपरोक्त कार्यक्रम चलाते हैं तो हमें निम्नलिखित आउटपुट मिलेंगे -

Type of mytable is 	table
mytable Element at index 1 is 	Lua
mytable Element at index wow is 	Tutorial
alternatetable Element at index 1 is 	Lua
alternatetable Element at index wow is 	Tutorial
mytable Element at index wow is 	I changed it
alternatetable is 	nil
mytable Element at index wow is 	I changed it
mytable is 	nil

तालिका में हेरफेर

टेबल हेरफेर के लिए अंतर्निहित कार्य हैं और वे निम्नलिखित तालिका में सूचीबद्ध हैं।

अनु क्रमांक। विधि और उद्देश्य
1

table.concat (table [, sep [, i [, j]]])

दिए गए मापदंडों के आधार पर तालिकाओं में तारों को समेटता है। विस्तार के लिए उदाहरण देखें।

2

table.insert (table, [pos,] value)

निर्दिष्ट स्थान पर तालिका में एक मूल्य सम्मिलित करता है।

3

table.maxn (table)

सबसे बड़ा संख्यात्मक सूचकांक लौटाता है।

4

table.remove (table [, pos])

तालिका से मान निकालता है।

5

table.sort (table [, comp])

वैकल्पिक तुलनित्र तर्क के आधार पर तालिका को सॉर्ट करता है।

हमें उपरोक्त कार्यों के कुछ नमूने देखें।

टेबल कॉनटेनटेशन

हम नीचे दिखाए गए अनुसार दो तालिकाओं को समतल करने के लिए कंकट फ़ंक्शन का उपयोग कर सकते हैं

fruits = {"banana","orange","apple"}

-- returns concatenated string of table
print("Concatenated string ",table.concat(fruits))

--concatenate with a character
print("Concatenated string ",table.concat(fruits,", "))

--concatenate fruits based on index
print("Concatenated string ",table.concat(fruits,", ", 2,3))

जब हम उपरोक्त कार्यक्रम चलाते हैं तो हमें निम्नलिखित आउटपुट मिलेंगे -

Concatenated string 	bananaorangeapple
Concatenated string 	banana, orange, apple
Concatenated string 	orange, apple

डालें और निकालें

तालिकाओं में वस्तुओं को सम्मिलित करना और हटाना टेबल हेरफेर में सबसे आम है। इसे नीचे समझाया गया है।

fruits = {"banana","orange","apple"}

-- insert a fruit at the end
table.insert(fruits,"mango")
print("Fruit at index 4 is ",fruits[4])

--insert fruit at index 2
table.insert(fruits,2,"grapes")
print("Fruit at index 2 is ",fruits[2])

print("The maximum elements in table is",table.maxn(fruits))

print("The last element is",fruits[5])

table.remove(fruits)
print("The previous last element is",fruits[5])

जब हम उपरोक्त कार्यक्रम चलाते हैं, तो हमें निम्न आउटपुट मिलेंगे -

Fruit at index 4 is 	mango
Fruit at index 2 is 	grapes
The maximum elements in table is	5
The last element is	mango
The previous last element is	nil

छाँटने वाली तालिकाएँ

हमें अक्सर किसी विशेष क्रम में तालिका को क्रमबद्ध करना होता है। सॉर्ट फ़ंक्शंस तत्वों को तालिका में वर्णानुक्रम में सॉर्ट करते हैं। इसके लिए एक नमूना नीचे दिखाया गया है।

fruits = {"banana","orange","apple","grapes"}

for k,v in ipairs(fruits) do
   print(k,v)
end

table.sort(fruits)
print("sorted table")

for k,v in ipairs(fruits) do
   print(k,v)
end

जब हम उपरोक्त कार्यक्रम चलाते हैं तो हमें निम्नलिखित आउटपुट मिलेंगे -

1	banana
2	orange
3	apple
4	grapes
sorted table
1	apple
2	banana
3	grapes
4	orange