इस लेख में, हम इस बात पर विचार करेंगे कि दो तिथियों के बीच कार्य घंटों की गणना कैसे करें। इस जानकारी की आवश्यकता कर्मचारियों के कार्य की दक्षता के विश्लेषण और टुकड़े-टुकड़े भुगतान प्रणाली के मामले में खर्च किए गए उपयोगी समय की गणना दोनों के लिए हो सकती है।
तो, आइए काम के घंटे गिनने में मदद के लिए अपना स्वयं का फ़ंक्शन लिखें और इसे WORKHOURS कहें।
मेनू खोलें सेवा - मैक्रो - संपादक Visual Basic , नया मॉड्यूल डालें (मेन्यू
Function WORKHOURS(StartDate As Variant, EndDate As Variant) Application.Volatile StartDate = StartDate.Address EndDate = EndDate.Address ' पहले दिन के कामकाजी घंटे WORKHOURS1 = Evaluate("IF(AND(DAY(" & StartDate & ")=DAY(" & _ EndDate & "),MONTH(" & StartDate & ")=MONTH(" & EndDate & "))," & EndDate & _ "-" & StartDate & "-IF(AND(HOUR(" & StartDate & ")<=13,HOUR(" & EndDate & _ ")>=14),1/24,0),18/24-MOD(" & StartDate & ",1)-IF(HOUR(" & StartDate & _ ")<=13,1/24,0))") ' मध्यवर्ती दिनों के कार्य घंटे WORKHOURS2 = Evaluate("MAX((IF(AND((WEEKDAY(" & EndDate & ",2))"&"<"&"(WEEKDAY(" & StartDate & _ ",2)),((WEEKDAY(" & StartDate & ",2))-(WEEKDAY(" & EndDate & ",2)))>1),(((DATEDIF(" & StartDate & _ "," & EndDate & "," & """D""" & ")+1))-(FLOOR((DATEDIF(" & StartDate & "," & EndDate & _ "," & """D""" & ")+1)/7,1)*2)-2),(((DATEDIF(" & StartDate & "," & EndDate & "," & """D""" & ")+1))-(FLOOR((DATEDIF(" & _ StartDate & "," & EndDate & "," & """D""" & ")+1)/7,1)*2)))-2),0)*8/24") ' अंतिम दिन के कार्य घंटे WORKHOURS3 = Evaluate("IF(AND(DAY(" & StartDate & _ ")=DAY(" & EndDate & "),MONTH(" & StartDate & ")=MONTH(" & EndDate & ")),0,MOD(" & EndDate & _ ",1)-9/24-IF(HOUR(" & EndDate & ")>=14,1/24,0))") WORKHOURS = WORKHOURS1 + WORKHOURS2 + WORKHOURS3 End Function
Visual Basic संपादक को बंद करें और Excel पर वापस लौटें।
अभी इसमें फंक्शन मास्टर्स श्रेणी में उपयोगकर्ता परिभाषित आप हमारा WORKHOURS फ़ंक्शन ढूंढ सकते हैं और उसका उपयोग कर सकते हैं। फ़ंक्शन सिंटैक्स अगले:
=WORKHOURS(प्रारंभ_दिनांक; समाप्ति_दिनांक)