एक्सेल डैक्स - टाइम इंटेलिजेंस का उपयोग करना

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

DAX समय खुफिया कार्यों में शामिल हैं -

  • कार्य जो आपके डेटा से दिनांक या दिनांक को प्राप्त करने में आपकी सहायता करते हैं, जिनका उपयोग समान अवधि में मानों की गणना करने के लिए किया जाता है।

  • कार्य जो मानक तिथि अंतराल के साथ काम करते हैं, आपको महीनों, वर्षों या तिमाहियों के मूल्यों की तुलना करने की अनुमति देते हैं।

  • कार्य जो एक निर्दिष्ट अवधि की पहली और आखिरी तारीख को पुनः प्राप्त करते हैं।

  • कार्य जो आपको उद्घाटन और समापन संतुलन पर काम करने में मदद करते हैं।

संचयी बिक्री की गणना

संचयी बिक्री की गणना के लिए सूत्र बनाने के लिए आप DAX समय के खुफिया कार्यों का उपयोग कर सकते हैं। निम्नलिखित DAX फ़ंक्शंस का उपयोग बंद करने और खोलने के संतुलन की गणना के लिए किया जा सकता है

CLOSINGBALANCEMONTH (<expression>,<dates>, [<filter>]) - वर्तमान संदर्भ में महीने की अंतिम तारीख को अभिव्यक्ति का मूल्यांकन करता है।

OPENINGBALANCEMONTH (<expression>,<dates>, [<filter>]) - वर्तमान संदर्भ में महीने की पहली तारीख को अभिव्यक्ति का मूल्यांकन करता है।

CLOSINGBALANCEQUARTER (<expression>,<dates>, [<filter>]) - वर्तमान संदर्भ में तिमाही की अंतिम तारीख में अभिव्यक्ति का मूल्यांकन करता है।

OPENINGBALANCEQUARTER (<expression>,<dates>, [<filter>]) - वर्तमान संदर्भ में तिमाही की पहली तारीख को अभिव्यक्ति का मूल्यांकन करता है।

CLOSINGBALANCEYEAR (<expression>,<dates>, [<filter>], [<year_end_date>]) - वर्तमान संदर्भ में वर्ष की अंतिम तिथि में अभिव्यक्ति का मूल्यांकन करता है।

OPENINGBALANCEYEAR (<expression>, <dates>, <filter>], [<year_end_date>]) - वर्तमान संदर्भ में वर्ष की पहली तारीख को अभिव्यक्ति का मूल्यांकन करता है।

आप निम्नलिखित DAX फ़ंक्शंस का उपयोग करके निर्दिष्ट समय में उत्पाद सूची के लिए निम्नलिखित परिकलित फ़ील्ड बना सकते हैं -

Month Start Inventory Value: = OPENINGBALANCEMONTH ( 
   SUMX (ProductInventory, ProductInventory[UnitCost]*ProductInventory[UnitsBalance]), DateTime[DateKey]
)
Month End Inventory Value: = CLOSINGBALANCEMONTH ( 
   SUMX (ProductInventory, ProductInventory[UnitCost]*ProductInventory[UnitsBalance]), DateTime[DateKey]
)
Quarter Start Inventory Value: = OPENINGBALANCEQUARTER ( 
   SUMX ProductInventory, (ProductInventory[UnitCost]*ProductInventory[UnitsBalance]), DateTime[DateKey]
)
Quarter End Inventory Value: = CLOSINGBALANCEQUARTER ( 
   SUMX (ProductInventory, ProductInventory[UnitCost]*ProductInventory[UnitsBalance]), DateTime[DateKey]
)
Year Start Inventory Value: = OPENINGBALANCEYEAR ( 
   SUMX (ProductInventory, ProductInventory[UnitCost]*ProductInventory[UnitsBalance]), DateTime[DateKey]
)
Year End Inventory Value: = CLOSINGBALANCEYEAR ( 
   SUMX (ProductInventory, ProductInventory[UnitCost]*ProductInventory[UnitsBalance]), DateTime[DateKey]
)

विभिन्न समयावधियों में मूल्यों की तुलना करना

DAX द्वारा समर्थित डिफ़ॉल्ट समय अवधि महीने, तिमाही और वर्ष हैं।

आप विभिन्न समय अवधि में रकम की तुलना करने के लिए निम्नलिखित DAX समय खुफिया कार्यों का उपयोग कर सकते हैं।

  • PREVIOUSMONTH (<dates>) - वर्तमान संदर्भ में तिथियों के कॉलम में पहली तारीख के आधार पर, एक तालिका जिसमें पिछले महीने की सभी तिथियों का एक कॉलम होता है।

  • PREVIOUSQUARTER (<dates>) - वर्तमान संदर्भ में तिथियों के कॉलम में पहली तारीख के आधार पर, पिछली तालिका से सभी तिथियों का एक स्तंभ शामिल करने वाली तालिका लौटाता है।

  • PREVIOUSYEAR (<dates>, <year_end_date>]) - एक तालिका लौटाता है जिसमें पिछले वर्ष से सभी तिथियों का एक कॉलम होता है, जो वर्तमान संदर्भ में तारीखों के कॉलम में अंतिम तिथि को दिया जाता है।

आप DAX का उपयोग करके, तुलना के लिए निर्दिष्ट समय अवधि में पश्चिम क्षेत्र में बिक्री के योग की गणना के लिए निम्नलिखित गणना किए गए फ़ील्ड बना सकते हैं:

Previous Month Sales: = CALCULATE ( 
   SUM (WestSales[SalesAmount]), PREVIOUSMONTH (DateTime [DateKey])
)
Previous Quarter Sales: = CALCULATE ( 
   SUM (WestSales[SalesAmount]), PREVIOUSQUARTER (DateTime [DateKey])
)
Previous Year Sales: = CALCULATE ( 
   SUM (WestSales[SalesAmount]), PREVIOUSYEAR (DateTime [DateKey])
)

समांतर समयावधि में मानों की तुलना करना

आप निर्दिष्ट समय अवधि के समानांतर अवधि के दौरान रकम की तुलना करने के लिए DAX समय खुफिया फ़ंक्शन PARALLELPERIOD का उपयोग कर सकते हैं।

PARALLELPERIOD (<तिथियाँ>, <number_of_intervals>, <interval>)

यह DAX फ़ंक्शन एक तालिका लौटाता है जिसमें तिथियों का एक कॉलम होता है जो निर्दिष्ट तिथियों के कॉलम में तारीखों के समानांतर एक अवधि का प्रतिनिधित्व करता है, वर्तमान संदर्भ में, समय के साथ कई अंतरालों को स्थानांतरित किया जाता है।

आप पश्चिम क्षेत्र में पिछले वर्ष की बिक्री की गणना के लिए निम्नलिखित गणना क्षेत्र बना सकते हैं -

Previous Year Sales: = CALCULATE ( 
   SUM (West_Sales[SalesAmount]), PARALLELPERIOD (DateTime[DateKey],-1,year)
)

रनिंग टोटल की गणना

आप चल रहे योग या चलने वाले योगों की गणना करने के लिए निम्नलिखित DAX समय के खुफिया कार्यों का उपयोग कर सकते हैं।

  • TOTALMTD (<expression>,<dates>, [<filter>]) - वर्तमान संदर्भ में महीने के लिए अभिव्यक्ति के मूल्य का मूल्यांकन करता है।

  • TOTALQTD (<expression>,<dates>, <filter>]) - वर्तमान संदर्भ में तिमाही से तारीख तक की तारीखों के लिए अभिव्यक्ति के मूल्य का मूल्यांकन करता है।

  • TOTALYTD (<expression>,<dates>, [<filter>], [<year_end_date>]) - वर्तमान संदर्भ में अभिव्यक्ति के वर्ष-दर-वर्ष के मूल्य का मूल्यांकन करता है।

आप DAX फ़ंक्शंस का उपयोग करके निर्दिष्ट समय अवधि में पश्चिम क्षेत्र में बिक्री की कुल राशि की गणना के लिए निम्नलिखित परिकलित फ़ील्ड बना सकते हैं -

मासिक रनिंग सम: = TOTALMTD (SUM (West_Sales [SalesAmount]), DateTime [डेटऑनडे])

क्वार्टर रनिंग सम: = TOTALQTD (SUM (WestSales [SalesAmount]), DateTime [DateBey])

वर्ष चलने का योग: = TOTALYTD (SUM (WestSales [SalesAmount]), DateTime [DateKey]

एक कस्टम तिथि सीमा पर मान की गणना करना

आप DAX समय खुफिया फ़ंक्शन का उपयोग कस्टम तिथियों को प्राप्त करने के लिए कर सकते हैं, जिसका उपयोग आप एक DAX फ़ंक्शन के इनपुट के रूप में कर सकते हैं, जो समय-समय पर कस्टम समुच्चय बनाने के लिए, गणना करता है।

DATESINPERIOD (<dates>, <start_date>, <number_of_intervals>, <interval>) - एक तालिका लौटाता है जिसमें तिथियों का एक स्तंभ होता है जो start_date से शुरू होता है और निर्दिष्ट संख्या_of_intervals के लिए जारी रहता है।

DATESBETWEEN (<dates>, <start_date>, ) - एक ऐसी तालिका लौटाता है जिसमें तारीखों का एक कॉलम होता है जो start_date से शुरू होता है और अंत_date तक जारी रहता है।

DATEADD (<dates>,<number_of_intervals>,<interval>) - ऐसी तालिका लौटाता है जिसमें तारीखों का एक कॉलम होता है, जो वर्तमान संदर्भ में तारीखों से निर्दिष्ट अंतराल द्वारा समय में आगे या पीछे स्थानांतरित हो जाता है।

FIRSTDATE (<dates>) - तारीखों के निर्दिष्ट कॉलम के लिए वर्तमान संदर्भ में पहली तारीख लौटाता है।

LASTDATE (<dates>) - तारीखों के निर्दिष्ट कॉलम के लिए वर्तमान संदर्भ में अंतिम तारीख लौटाता है।

पश्चिम क्षेत्र में बिक्री की राशि की गणना के लिए आप DAX सूत्रों का उपयोग करके निम्नलिखित DAX सूत्र बना सकते हैं -

  • DAX फॉर्मूला 17 जुलाई 2016 से पहले 15 दिनों के लिए बिक्री की गणना करने के लिए।

CALCULATE ( 
   SUM (WestSales[SalesAmount]), DATESINPERIOD (DateTime[DateKey], DATE(2016,17,14), -15, day)
)
  • DAX फॉर्मूला एक गणना क्षेत्र बनाने के लिए है जो पहली तिमाही 2016 की बिक्री की गणना करता है।

= CALCULATE (
   SUM (WestSales[SalesAmount]),DATESBETWEEN (DateTime[DateKey], DATE (2016,1,1), DATE (2016,3,31))
)
  • DAX फॉर्मूला एक परिकलित फ़ील्ड बनाने के लिए जो वर्तमान संदर्भ के लिए पश्चिम क्षेत्र में बिक्री किए जाने पर पहली तारीख प्राप्त करता है।

= FIRSTDATE (WestSales [SaleDateKey])
  • DAX फॉर्मूला एक परिकलित फ़ील्ड बनाने के लिए है जो वर्तमान संदर्भ के लिए पश्चिम क्षेत्र में बिक्री किए जाने पर अंतिम तिथि प्राप्त करता है।

= LASTDATE (WestSales [SaleDateKey])
  • DAX फॉर्मूला वर्तमान संदर्भ में तारीखों से एक वर्ष पहले की तारीखों की गणना करने के लिए।

= DATEADD (DateTime[DateKey],-1,year)