क्यू भाषा - शब्दकोशों
शब्दकोश सूचियों का एक विस्तार है जो तालिका बनाने के लिए आधार प्रदान करते हैं। गणितीय शब्दों में, शब्दकोश बनाता है
"डोमेन → रेंज"
या सामान्य रूप से (छोटा) बनाता है
"कुंजी → मूल्य"
तत्वों के बीच संबंध।
एक शब्दकोश कुंजी-मूल्य वाले जोड़े का एक आदेशित संग्रह है जो मोटे तौर पर एक हैश तालिका के बराबर है। एक शब्दकोष एक स्पष्ट आई / ओ एसोसिएशन द्वारा एक डोमेन सूची और एक पोजिशन लिस्ट के बीच स्थितीय पत्राचार के माध्यम से परिभाषित मानचित्रण है। एक शब्दकोश का निर्माण "xkey" आदिम (!) का उपयोग करता है
ListOfDomain ! ListOfRange
सबसे बुनियादी शब्दकोश एक सरल सूची के लिए एक सरल सूची का मानचित्र बनाता है।
इनपुट (I) | आउटपुट (O) |
---|---|
`नाम | `जॉन |
`उम्र | 36 |
`सेक्स | "म" |
वजन | 60.3 |
q)d:`Name`Age`Sex`Weight!(`John;36;"M";60.3) / Create a dictionary d
q)d
Name | `John
Age | 36
Sex | "M"
Weight | 60.3
q)count d / To get the number of rows in a dictionary.
4
q)key d / The function key returns the domain
`Name`Age`Sex`Weight
q)value d / The function value returns the range.
`John
36
"M"
60.3
q)cols d / The function cols also returns the domain.
`Name`Age`Sex`Weight
देखो
इनपुट वैल्यू के अनुरूप डिक्शनरी आउटपुट वैल्यू को ढूंढना कहा जाता है looking up इनपुट।
q)d[`Name] / Accessing the value of domain `Name
`John
q)d[`Name`Sex] / extended item-wise to a simple list of keys
`John
"M"
Verb @ के साथ लुकअप
q)d1:`one`two`three!9 18 27
q)d1[`two]
18
q)d1@`two
18
शब्दकोशों पर संचालन
संशोधन और उपरि
सूचियों के साथ, शब्दकोश की वस्तुओं को अनुक्रमित असाइनमेंट के माध्यम से संशोधित किया जा सकता है।
d:`Name`Age`Sex`Weight! (`John;36;"M";60.3)
/ A dictionary d
q)d[`Age]:35 / Assigning new value to key Age
q)d
/ New value assigned to key Age in d
Name | `John
Age | 35
Sex | "M"
Weight | 60.3
इंडेक्स असाइनमेंट के जरिए डिक्शनरी बढ़ाई जा सकती है।
q)d[`Height]:"182 Ft"
q)d
Name | `John
Age | 35
Sex | "M"
Weight | 60.3
Height | "182 Ft"
लुकअप के साथ लुकअप (?)
खोज (?) ऑपरेटर का उपयोग उसके डोमेन तत्व में तत्वों की एक श्रृंखला को मैप करके रिवर्स लुकअप करने के लिए किया जाता है।
q)d2:`x`y`z!99 88 77
q)d2?77
`z
मामले में एक सूची के तत्व अद्वितीय नहीं हैं, find डोमेन सूची से इसमें पहला आइटम मैपिंग देता है।
प्रविष्टियां निकालना
एक शब्दकोश से एक प्रविष्टि को हटाने के लिए, delete ( _ ) functionप्रयोग किया जाता है। (_) के बाएं ऑपरेंड डिक्शनरी है और राइट ऑपरेंड एक महत्वपूर्ण मूल्य है।
q)d2:`x`y`z!99 88 77
q)d2 _`z
x| 99
y| 88
व्हाट्सएप _ के बाईं ओर आवश्यक है यदि पहला ऑपरेंड एक चर है।
q)`x`y _ d2 / Deleting multiple entries
z| 77
कॉलम शब्दकोश
कॉलम के निर्माण के लिए कॉलम शब्दकोशों मूल बातें हैं। निम्नलिखित उदाहरण पर विचार करें -
q)scores: `name`id!(`John`Jenny`Jonathan;9 18 27)
/ Dictionary scores
q)scores[`name] / The values for the name column are
`John`Jenny`Jonathan
q)scores.name / Retrieving the values for a column in a
/ column dictionary using dot notation.
`John`Jenny`Jonathan
q)scores[`name][1] / Values in row 1 of the name column
`Jenny
q)scores[`id][2] / Values in row 2 of the id column is
27
एक फ़्लिपिंग
कॉलम शब्दकोश को फ़्लिप करने का शुद्ध प्रभाव सूचकांकों के क्रम को उलट रहा है। यह तार्किक रूप से पंक्तियों और स्तंभों को स्थानांतरित करने के बराबर है।
एक कॉलम शब्दकोश पर पलटें
डिक्शनरी का ट्रांज़िशन, यूनियरी फ्लिप ऑपरेटर को लागू करके प्राप्त किया जाता है। निम्नलिखित उदाहरण पर एक नज़र डालें -
q)scores
name | John Jenny Jonathan
id | 9 18 27
q)flip scores
name id
---------------
John 9
Jenny 18
Jonathan 27
फ़्लिप किए गए कॉलम शब्दकोश का फ़्लिप
यदि आप किसी शब्दकोश को दो बार स्थानांतरित करते हैं, तो आप मूल शब्दकोश प्राप्त करते हैं,
q)scores ~ flip flip scores
1b