यूनिक्स टाइमस्टैम्प से दिनांक परिवर्तक: 12/24 घंटे प्रारूप समर्थन
यूनिक्स टाइमस्टैम्प को मानव-पठनीय दिनांक और समय में परिवर्तित करें। इस सरल, उपयोगकर्ता-अनुकूल परिवर्तक उपकरण के साथ 12-घंटे और 24-घंटे समय प्रारूप के बीच चुनें।
यूनिक्स टाइमस्टैम्प कनवर्टर
परिवर्तित दिनांक और समय
दस्तावेज़ीकरण
यूनिक्स टाइमस्टैम्प कनवर्टर
परिचय
यूनिक्स टाइमस्टैम्प (जिसे POSIX समय या एपोक समय भी कहा जाता है) एक समय बिंदु का वर्णन करने के लिए एक प्रणाली है। यह 1 जनवरी 1970 (मध्यरात्रि UTC/GMT) से बीते हुए सेकंडों की संख्या है, जिसमें लीप सेकंड को नहीं गिना जाता है। यूनिक्स टाइमस्टैम्प कंप्यूटर सिस्टम और प्रोग्रामिंग भाषाओं में व्यापक रूप से उपयोग किए जाते हैं क्योंकि ये एक विशिष्ट क्षण का संक्षिप्त, भाषा-स्वतंत्र प्रतिनिधित्व प्रदान करते हैं।
यह कनवर्टर आपको एक यूनिक्स टाइमस्टैम्प को मानव-पठनीय दिनांक और समय प्रारूप में परिवर्तित करने की अनुमति देता है। यह विभिन्न क्षेत्रीय और व्यक्तिगत प्राथमिकताओं को समायोजित करने के लिए 12-घंटे (AM/PM) और 24-घंटे समय प्रारूप दोनों का समर्थन करता है।
यूनिक्स टाइमस्टैम्प कैसे काम करते हैं
यूनिक्स टाइमस्टैम्प को यूनिक्स एपोक (1 जनवरी 1970, 00:00:00 UTC) से बीते सेकंडों की संख्या के रूप में गणना की जाती है। यह उन्हें समय भिन्नताओं की गणना करने और संक्षिप्त प्रारूप में तिथियों को संग्रहीत करने के लिए विशेष रूप से उपयोगी बनाता है।
यूनिक्स टाइमस्टैम्प से कैलेंडर दिनांक में रूपांतरण के लिए कई चरणों की आवश्यकता होती है:
- यूनिक्स एपोक (1 जनवरी 1970, 00:00:00 UTC) से शुरू करें
- टाइमस्टैम्प में सेकंडों की संख्या जोड़ें
- लीप वर्षों, विभिन्न महीने की लंबाई और अन्य कैलेंडर जटिलताओं का ध्यान रखें
- यदि आवश्यक हो तो टाइमज़ोन समायोजन लागू करें
उदाहरण के लिए, यूनिक्स टाइमस्टैम्प 1609459200
शुक्रवार, 1 जनवरी 2021, 00:00:00 UTC का प्रतिनिधित्व करता है।
रूपांतरण सूत्र को इस प्रकार व्यक्त किया जा सकता है:
अधिकांश प्रोग्रामिंग भाषाएँ और ऑपरेटिंग सिस्टम इस रूपांतरण को संभालने के लिए अंतर्निहित फ़ंक्शन प्रदान करते हैं, जटिल कैलेंडर गणनाओं को छिपाते हुए।
समय प्रारूप विकल्प
यह कनवर्टर दो समय प्रारूप विकल्प प्रदान करता है:
-
24-घंटे प्रारूप (जिसे कभी-कभी "सैन्य समय" कहा जाता है): घंटे 0 से 23 के बीच होते हैं, और AM/PM नामकरण नहीं होता है। उदाहरण के लिए, 3:00 PM को 15:00 के रूप में दर्शाया जाता है।
-
12-घंटे प्रारूप: घंटे 1 से 12 के बीच होते हैं, जिसमें मध्यरात्रि से दोपहर तक के समय के लिए AM (ante meridiem) और दोपहर से मध्यरात्रि तक के समय के लिए PM (post meridiem) होता है। उदाहरण के लिए, 24-घंटे प्रारूप में 15:00 को 3:00 PM के रूप में दर्शाया जाता है।
इन प्रारूपों के बीच चयन मुख्यतः क्षेत्रीय परंपरा और व्यक्तिगत पसंद का मामला है:
- 24-घंटे प्रारूप का उपयोग अधिकांश यूरोप, लैटिन अमेरिका और एशिया में, साथ ही वैज्ञानिक, सैन्य और चिकित्सा संदर्भों में विश्व स्तर पर किया जाता है।
- 12-घंटे प्रारूप का उपयोग संयुक्त राज्य अमेरिका, कनाडा, ऑस्ट्रेलिया और कुछ अन्य अंग्रेजी बोलने वाले देशों में दैनिक उपयोग के लिए किया जाता है।
किनारे के मामले और सीमाएँ
यूनिक्स टाइमस्टैम्प के साथ काम करते समय, कई किनारे के मामलों और सीमाओं के बारे में जागरूक होना महत्वपूर्ण है:
-
नकारात्मक टाइमस्टैम्प: ये यूनिक्स एपोक (1 जनवरी 1970) से पहले की तिथियों का प्रतिनिधित्व करते हैं। जबकि गणितीय रूप से मान्य हैं, कुछ सिस्टम नकारात्मक टाइमस्टैम्प को सही तरीके से संभाल नहीं सकते हैं।
-
2038 समस्या: यूनिक्स टाइमस्टैम्प अक्सर 32-बिट साइन किए गए पूर्णांकों के रूप में संग्रहीत किए जाते हैं, जो 19 जनवरी 2038 को ओवरफ्लो हो जाएंगे। इस बिंदु के बाद, 32-बिट सिस्टम समय को सही तरीके से प्रदर्शित करने में असमर्थ होंगे जब तक कि उन्हें बड़े पूर्णांक प्रकार का उपयोग करने के लिए संशोधित नहीं किया जाता।
-
अत्यधिक बड़े टाइमस्टैम्प: बहुत दूर के भविष्य की तिथियाँ कुछ सिस्टम में प्रदर्शित नहीं की जा सकती हैं, या असंगत रूप से संभाली जा सकती हैं।
-
लीप सेकंड: यूनिक्स समय लीप सेकंड का ध्यान नहीं रखता है, जो UTC में पृथ्वी की अनियमित घूर्णन के लिए समय-समय पर जोड़े जाते हैं। इसका अर्थ है कि यूनिक्स समय खगोलीय समय के साथ सटीक रूप से समन्वयित नहीं है।
-
टाइमज़ोन पर विचार: यूनिक्स टाइमस्टैम्प क्षणों का प्रतिनिधित्व UTC में करते हैं। स्थानीय समय में परिवर्तित करने के लिए अतिरिक्त टाइमज़ोन जानकारी की आवश्यकता होती है।
-
डेयलाइट सेविंग टाइम: टाइमस्टैम्प को स्थानीय समय में परिवर्तित करते समय, डेयलाइट सेविंग टाइम परिवर्तनों की जटिलताओं पर विचार करना आवश्यक है।
उपयोग के मामले
यूनिक्स टाइमस्टैम्प का उपयोग कंप्यूटिंग और डेटा प्रबंधन में कई अनुप्रयोगों में किया जाता है:
-
डेटाबेस रिकॉर्ड: टाइमस्टैम्प का उपयोग आमतौर पर यह रिकॉर्ड करने के लिए किया जाता है कि प्रविष्टियाँ कब बनाई गईं या संशोधित की गईं।
-
वेब विकास: HTTP हेडर, कुकीज़ और कैशिंग तंत्र अक्सर यूनिक्स टाइमस्टैम्प का उपयोग करते हैं।
-
लॉग फ़ाइलें: सिस्टम लॉग आमतौर पर घटनाओं को सटीक कालक्रम में रिकॉर्ड करने के लिए यूनिक्स टाइमस्टैम्प के साथ रिकॉर्ड करते हैं।
-
संस्करण नियंत्रण प्रणाली: Git और अन्य VCS टाइमस्टैम्प का उपयोग करते हैं ताकि यह रिकॉर्ड किया जा सके कि कमिट कब किए गए थे।
-
API प्रतिक्रियाएँ: कई वेब APIs अपने उत्तरों में टाइमस्टैम्प शामिल करते हैं ताकि यह संकेत दिया जा सके कि डेटा कब उत्पन्न किया गया था या संसाधनों को कब अंतिम बार संशोधित किया गया था।
-
फाइल सिस्टम: फ़ाइल निर्माण और संशोधन समय अक्सर यूनिक्स टाइमस्टैम्प के रूप में संग्रहीत होते हैं।
-
सत्र प्रबंधन: वेब अनुप्रयोग टाइमस्टैम्प का उपयोग करते हैं ताकि यह निर्धारित किया जा सके कि उपयोगकर्ता सत्र कब समाप्त होना चाहिए।
-
डेटा विश्लेषण: टाइमस्टैम्प विश्लेषण अनुप्रयोगों में अस्थायी डेटा के साथ काम करने के लिए एक मानकीकृत तरीका प्रदान करते हैं।
विकल्प
हालांकि यूनिक्स टाइमस्टैम्प का व्यापक उपयोग होता है, कुछ संदर्भों में अधिक उपयुक्त समय प्रतिनिधित्व प्रारूप हो सकते हैं:
-
ISO 8601: एक मानकीकृत स्ट्रिंग प्रारूप (जैसे, "2021-01-01T00:00:00Z") जो मानव-पठनीय है जबकि क्रमबद्धता बनाए रखता है। यह डेटा इंटरचेंज और उपयोगकर्ता-सम्पर्क अनुप्रयोगों के लिए अक्सर पसंद किया जाता है।
-
RFC 3339: इंटरनेट प्रोटोकॉल में उपयोग के लिए ISO 8601 का एक प्रोफ़ाइल, जिसमें कड़े प्रारूपण आवश्यकताएँ होती हैं।
-
मानव-पठनीय प्रारूप: स्थानीयकृत दिनांक स्ट्रिंग (जैसे, "1 जनवरी 2021") सीधे उपयोगकर्ता इंटरैक्शन के लिए अधिक उपयुक्त होती हैं लेकिन गणना के लिए कम उपयुक्त होती हैं।
-
माइक्रोसॉफ्ट FILETIME: एक 64-बिट मान जो 1 जनवरी 1601 से 100-नैनोसेकंड अंतरालों की संख्या का प्रतिनिधित्व करता है, जिसका उपयोग Windows सिस्टम में किया जाता है।
-
जूलियन डे नंबर: खगोल विज्ञान और कुछ वैज्ञानिक अनुप्रयोगों में उपयोग किया जाता है, जो 4713 BCE से दिनों की गिनती करता है।
समय प्रारूप का चयन कई कारकों पर निर्भर करता है जैसे:
- आवश्यक सटीकता
- मानव पठनीयता की आवश्यकताएँ
- भंडारण की सीमाएँ
- मौजूदा सिस्टम के साथ संगतता
- उन तिथियों की सीमा जो प्रदर्शित करने की आवश्यकता है
इतिहास
यूनिक्स समय की अवधारणा यूनिक्स ऑपरेटिंग सिस्टम के विकास के साथ उत्पन्न हुई, जो बेल लैब्स में 1960 के दशक और 1970 के दशक की शुरुआत में विकसित की गई थी। एपोक के रूप में 1 जनवरी 1970 का उपयोग करना कुछ हद तक मनमाना था लेकिन उस समय के लिए व्यावहारिक था—यह रुचि की तिथियों के लिए भंडारण आवश्यकताओं को कम करने के लिए हाल के समय में था लेकिन ऐतिहासिक डेटा के लिए उपयोगी होने के लिए काफी दूर था।
मूल कार्यान्वयन ने सेकंडों की संख्या को संग्रहीत करने के लिए 32-बिट साइन किए गए पूर्णांक का उपयोग किया, जो उस समय यूनिक्स सिस्टम के अपेक्षित जीवनकाल के लिए पर्याप्त था। हालाँकि, इस निर्णय ने 2038 समस्या (कभी-कभी "Y2K38" या "यूनिक्स सहस्त्राब्दी बग" कहा जाता है) को जन्म दिया, क्योंकि 32-बिट साइन किए गए पूर्णांक केवल 1 जनवरी 2038 (03:14:07 UTC) तक की तिथियों का प्रतिनिधित्व कर सकते हैं।
जैसे-जैसे यूनिक्स और यूनिक्स-जैसे ऑपरेटिंग सिस्टम लोकप्रियता प्राप्त करते गए, यूनिक्स टाइमस्टैम्प कंप्यूटिंग में एक मानक के रूप में स्थापित हो गया। इसे कई प्रोग्रामिंग भाषाओं, डेटाबेस और अनुप्रयोगों द्वारा अपनाया गया, जो इसके मूल यूनिक्स वातावरण से बहुत दूर तक फैला।
आधुनिक सिस्टम increasingly 64-बिट पूर्णांकों का उपयोग करते हैं, जो एपोक से लगभग 292 बिलियन वर्षों के भीतर दोनों दिशाओं में प्रदर्शित करने की सीमा को बढ़ाता है, प्रभावी रूप से 2038 समस्या को हल करता है। हालाँकि, विरासती सिस्टम और अनुप्रयोग अभी भी संवेदनशील हो सकते हैं।
यूनिक्स टाइमस्टैम्प की सरलता और उपयोगिता ने इसके अधिक परिष्कृत समय प्रतिनिधित्व प्रारूपों के विकास के बावजूद इसकी निरंतर प्रासंगिकता को सुनिश्चित किया है। यह कंप्यूटिंग में एक मौलिक अवधारणा बनी हुई है, जो हमारे डिजिटल बुनियादी ढांचे के अधिकांश को आधार प्रदान करती है।
कोड उदाहरण
यहाँ विभिन्न प्रोग्रामिंग भाषाओं में यूनिक्स टाइमस्टैम्प को मानव-पठनीय तिथियों में परिवर्तित करने के उदाहरण दिए गए हैं:
1// जावास्क्रिप्ट टाइमस्टैम्प रूपांतरण
2function convertUnixTimestamp(timestamp, use12Hour = false) {
3 // एक नया Date ऑब्जेक्ट बनाएं (जावास्क्रिप्ट मिलीसेकंड का उपयोग करता है)
4 const date = new Date(timestamp * 1000);
5
6 // प्रारूप विकल्प
7 const options = {
8 year: 'numeric',
9 month: 'long',
10 day: 'numeric',
11 weekday: 'long',
12 hour: use12Hour ? 'numeric' : '2-digit',
13 minute: '2-digit',
14 second: '2-digit',
15 hour12: use12Hour
16 };
17
18 // स्थानीय प्रारूपण का उपयोग करके स्ट्रिंग में परिवर्तित करें
19 return date.toLocaleString(undefined, options);
20}
21
22// उदाहरण उपयोग
23const timestamp = 1609459200; // 1 जनवरी 2021 00:00:00 UTC
24console.log(convertUnixTimestamp(timestamp, false)); // 24-घंटे प्रारूप
25console.log(convertUnixTimestamp(timestamp, true)); // 12-घंटे प्रारूप
26
1# पायथन टाइमस्टैम्प रूपांतरण
2import datetime
3
4def convert_unix_timestamp(timestamp, use_12hour=False):
5 # यूनिक्स टाइमस्टैम्प को datetime ऑब्जेक्ट में परिवर्तित करें
6 date = datetime.datetime.fromtimestamp(timestamp)
7
8 # दिनांक स्ट्रिंग का प्रारूप
9 if use_12hour:
10 format_string = "%A, %B %d, %Y %I:%M:%S %p" # 12-घंटे प्रारूप AM/PM के साथ
11 else:
12 format_string = "%A, %B %d, %Y %H:%M:%S" # 24-घंटे प्रारूप
13
14 return date.strftime(format_string)
15
16# उदाहरण उपयोग
17timestamp = 1609459200 # 1 जनवरी 2021 00:00:00 UTC
18print(convert_unix_timestamp(timestamp, False)) # 24-घंटे प्रारूप
19print(convert_unix_timestamp(timestamp, True)) # 12-घंटे प्रारूप
20
1<?php
2// PHP टाइमस्टैम्प रूपांतरण
3function convertUnixTimestamp($timestamp, $use12Hour = false) {
4 // प्रारूप स्ट्रिंग
5 $formatString = $use12Hour
6 ? 'l, F j, Y g:i:s A' // 12-घंटे प्रारूप AM/PM के साथ
7 : 'l, F j, Y H:i:s'; // 24-घंटे प्रारूप
8
9 // परिवर्तित और प्रारूपित करें
10 return date($formatString, $timestamp);
11}
12
13// उदाहरण उपयोग
14$timestamp = 1609459200; // 1 जनवरी 2021 00:00:00 UTC
15echo convertUnixTimestamp($timestamp, false) . "\n"; // 24-घंटे प्रारूप
16echo convertUnixTimestamp($timestamp, true) . "\n"; // 12-घंटे प्रारूप
17?>
18
1// जावा टाइमस्टैम्प रूपांतरण
2import java.time.Instant;
3import java.time.LocalDateTime;
4import java.time.ZoneId;
5import java.time.format.DateTimeFormatter;
6
7public class UnixTimestampConverter {
8 public static String convertUnixTimestamp(long timestamp, boolean use12Hour) {
9 // यूनिक्स टाइमस्टैम्प को Instant में परिवर्तित करें, फिर LocalDateTime में
10 Instant instant = Instant.ofEpochSecond(timestamp);
11 LocalDateTime dateTime = LocalDateTime.ofInstant(instant, ZoneId.systemDefault());
12
13 // वांछित प्रारूप के आधार पर फ़ॉर्मेटर बनाएं
14 DateTimeFormatter formatter = DateTimeFormatter.ofPattern(
15 use12Hour ? "EEEE, MMMM d, yyyy h:mm:ss a" : "EEEE, MMMM d, yyyy HH:mm:ss"
16 );
17
18 // दिनांक को प्रारूपित करें
19 return dateTime.format(formatter);
20 }
21
22 public static void main(String[] args) {
23 long timestamp = 1609459200; // 1 जनवरी 2021 00:00:00 UTC
24 System.out.println(convertUnixTimestamp(timestamp, false)); // 24-घंटे प्रारूप
25 System.out.println(convertUnixTimestamp(timestamp, true)); // 12-घंटे प्रारूप
26 }
27}
28
1// C# टाइमस्टैम्प रूपांतरण
2using System;
3
4class UnixTimestampConverter
5{
6 public static string ConvertUnixTimestamp(long timestamp, bool use12Hour)
7 {
8 // यूनिक्स टाइमस्टैम्प को DateTime में परिवर्तित करें
9 // यूनिक्स टाइमस्टैम्प 1970-01-01 से सेकंड हैं
10 DateTime dateTime = DateTimeOffset.FromUnixTimeSeconds(timestamp).DateTime;
11
12 // 12-घंटे या 24-घंटे प्राथमिकता के आधार पर प्रारूप स्ट्रिंग
13 string formatString = use12Hour
14 ? "dddd, MMMM d, yyyy h:mm:ss tt" // 12-घंटे प्रारूप AM/PM के साथ
15 : "dddd, MMMM d, yyyy HH:mm:ss"; // 24-घंटे प्रारूप
16
17 // प्रारूपित दिनांक स्ट्रिंग लौटाएँ
18 return dateTime.ToString(formatString);
19 }
20
21 static void Main()
22 {
23 long timestamp = 1609459200; // 1 जनवरी 2021 00:00:00 UTC
24 Console.WriteLine(ConvertUnixTimestamp(timestamp, false)); // 24-घंटे प्रारूप
25 Console.WriteLine(ConvertUnixTimestamp(timestamp, true)); // 12-घंटे प्रारूप
26 }
27}
28
1# रूबी टाइमस्टैम्प रूपांतरण
2require 'time'
3
4def convert_unix_timestamp(timestamp, use_12hour = false)
5 # यूनिक्स टाइमस्टैम्प को Time ऑब्जेक्ट में परिवर्तित करें
6 time = Time.at(timestamp)
7
8 # 12-घंटे या 24-घंटे प्राथमिकता के आधार पर प्रारूप
9 if use_12hour
10 time.strftime("%A, %B %d, %Y %I:%M:%S %p") # 12-घंटे प्रारूप AM/PM के साथ
11 else
12 time.strftime("%A, %B %d, %Y %H:%M:%S") # 24-घंटे प्रारूप
13 end
14end
15
16# उदाहरण उपयोग
17timestamp = 1609459200 # 1 जनवरी 2021 00:00:00 UTC
18puts convert_unix_timestamp(timestamp, false) # 24-घंटे प्रारूप
19puts convert_unix_timestamp(timestamp, true) # 12-घंटे प्रारूप
20
1// गो टाइमस्टैम्प रूपांतरण
2package main
3
4import (
5 "fmt"
6 "time"
7)
8
9func convertUnixTimestamp(timestamp int64, use12Hour bool) string {
10 // यूनिक्स टाइमस्टैम्प को समय में परिवर्तित करें
11 t := time.Unix(timestamp, 0)
12
13 // 12-घंटे या 24-घंटे प्राथमिकता के आधार पर प्रारूप स्ट्रिंग
14 formatString := "Monday, January 2, 2006 "
15 if use12Hour {
16 formatString += "3:04:05 PM" // 12-घंटे प्रारूप AM/PM के साथ
17 } else {
18 formatString += "15:04:05" // 24-घंटे प्रारूप
19 }
20
21 // प्रारूपित समय लौटाएँ
22 return t.Format(formatString)
23}
24
25func main() {
26 timestamp := int64(1609459200) // 1 जनवरी 2021 00:00:00 UTC
27 fmt.Println(convertUnixTimestamp(timestamp, false)) // 24-घंटे प्रारूप
28 fmt.Println(convertUnixTimestamp(timestamp, true)) // 12-घंटे प्रारूप
29}
30
1// स्विफ्ट टाइमस्टैम्प रूपांतरण
2import Foundation
3
4func convertUnixTimestamp(_ timestamp: Int, use12Hour: Bool) -> String {
5 // यूनिक्स टाइमस्टैम्प से Date बनाएं
6 let date = Date(timeIntervalSince1970: TimeInterval(timestamp))
7
8 // DateFormatter बनाएं
9 let formatter = DateFormatter()
10 formatter.dateStyle = .full
11
12 // 12-घंटे या 24-घंटे प्राथमिकता के आधार पर समय शैली सेट करें
13 if use12Hour {
14 formatter.timeStyle = .medium
15 formatter.amSymbol = "AM"
16 formatter.pmSymbol = "PM"
17 } else {
18 formatter.timeStyle = .medium
19 formatter.dateFormat = formatter.dateFormat?.replacingOccurrences(of: "h:mm:ss a", with: "HH:mm:ss")
20 }
21
22 // प्रारूपित दिनांक लौटाएँ
23 return formatter.string(from: date)
24}
25
26// उदाहरण उपयोग
27let timestamp = 1609459200 // 1 जनवरी 2021 00:00:00 UTC
28print(convertUnixTimestamp(timestamp, use12Hour: false)) // 24-घंटे प्रारूप
29print(convertUnixTimestamp(timestamp, use12Hour: true)) // 12-घंटे प्रारूप
30
1# आर टाइमस्टैम्प रूपांतरण
2convert_unix_timestamp <- function(timestamp, use_12hour = FALSE) {
3 # यूनिक्स टाइमस्टैम्प को POSIXct दिनांक/समय में परिवर्तित करें
4 date_time <- as.POSIXct(timestamp, origin = "1970-01-01", tz = "UTC")
5
6 # 12-घंटे या 24-घंटे प्राथमिकता के आधार पर प्रारूप
7 if (use_12hour) {
8 format_string <- "%A, %B %d, %Y %I:%M:%S %p" # 12-घंटे प्रारूप AM/PM के साथ
9 } else {
10 format_string <- "%A, %B %d, %Y %H:%M:%S" # 24-घंटे प्रारूप
11 }
12
13 # प्रारूपित दिनांक स्ट्रिंग लौटाएँ
14 format(date_time, format_string)
15}
16
17# उदाहरण उपयोग
18timestamp <- 1609459200 # 1 जनवरी 2021 00:00:00 UTC
19cat(convert_unix_timestamp(timestamp, FALSE), "\n") # 24-घंटे प्रारूप
20cat(convert_unix_timestamp(timestamp, TRUE), "\n") # 12-घंटे प्रारूप
21
1% MATLAB टाइमस्टैम्प रूपांतरण
2function formattedDate = convertUnixTimestamp(timestamp, use12Hour)
3 % यूनिक्स टाइमस्टैम्प को MATLAB datetime में परिवर्तित करें
4 % MATLAB तिथियाँ 1900-01-01 से दिनों हैं, जिसमें 1 = 1900-01-01
5 % यूनिक्स टाइमस्टैम्प 1970-01-01 से सेकंड हैं
6
7 % पहले Excel दिनांक प्रारूप में परिवर्तित करें
8 % 25569 1900-01-01 और 1970-01-01 के बीच दिनों की संख्या है
9 excelDate = (timestamp / 86400) + 25569;
10
11 % 12-घंटे या 24-घंटे प्राथमिकता के आधार पर प्रारूप
12 if use12Hour
13 formattedDate = datestr(excelDate, 'dddd, mmmm dd, yyyy h:mm:ss AM/PM');
14 else
15 formattedDate = datestr(excelDate, 'dddd, mmmm dd, yyyy hh:mm:ss');
16 end
17end
18
19% उदाहरण उपयोग
20timestamp = 1609459200; % 1 जनवरी 2021 00:00:00 UTC
21disp(convertUnixTimestamp(timestamp, false)) % 24-घंटे प्रारूप
22disp(convertUnixTimestamp(timestamp, true)) % 12-घंटे प्रारूप
23
1' Excel VBA टाइमस्टैम्प रूपांतरण
2Function ConvertUnixTimestamp(timestamp As Long, Optional use12Hour As Boolean = False) As String
3 ' यूनिक्स टाइमस्टैम्प को Excel दिनांक/समय में परिवर्तित करें
4 ' Excel तिथियाँ 1900-01-01 से दिनों हैं, जिसमें 1 = 1900-01-01
5 ' यूनिक्स टाइमस्टैम्प 1970-01-01 से सेकंड हैं
6
7 ' पहले Excel दिनांक प्रारूप में परिवर्तित करें
8 ' 25569 1900-01-01 और 1970-01-01 के बीच दिनों की संख्या है
9 Dim excelDate As Double
10 excelDate = (timestamp / 86400) + 25569
11
12 ' 12-घंटे या 24-घंटे प्राथमिकता के आधार पर प्रारूप स्ट्रिंग
13 If use12Hour Then
14 ConvertUnixTimestamp = Format(excelDate, "dddd, mmmm d, yyyy h:mm:ss AM/PM")
15 Else
16 ConvertUnixTimestamp = Format(excelDate, "dddd, mmmm d, yyyy hh:mm:ss")
17 End If
18End Function
19
20' कार्यपत्रक में उपयोग:
21' =ConvertUnixTimestamp(1609459200, TRUE) ' 12-घंटे प्रारूप
22' =ConvertUnixTimestamp(1609459200, FALSE) ' 24-घंटे प्रारूप
23
किनारे के मामलों को संभालना
यूनिक्स टाइमस्टैम्प के साथ काम करते समय, किनारे के मामलों को सही तरीके से संभालना महत्वपूर्ण है। यहाँ कुछ सामान्य किनारे के मामलों को संभालने के उदाहरण दिए गए हैं:
1// जावास्क्रिप्ट किनारे के मामले संभालना
2function safeConvertTimestamp(timestamp, use12Hour = false) {
3 // जांचें कि टाइमस्टैम्प मान्य है या नहीं
4 if (timestamp === undefined || timestamp === null || isNaN(timestamp)) {
5 return "अमान्य टाइमस्टैम्प";
6 }
7
8 // नकारात्मक टाइमस्टैम्प की जांच करें (1970 से पहले की तिथियाँ)
9 if (timestamp < 0) {
10 // कुछ ब्राउज़र नकारात्मक टाइमस्टैम्प को सही तरीके से संभाल नहीं सकते हैं
11 // 1970 से पहले की तिथियों के लिए अधिक मजबूत दृष्टिकोण का उपयोग करें
12 const date = new Date(timestamp * 1000);
13 if (isNaN(date.getTime())) {
14 return "अमान्य दिनांक (1970 से पहले)";
15 }
16 }
17
18 // Y2K38 समस्या के लिए जांचें (32-बिट सिस्टम के लिए)
19 const maxInt32 = 2147483647; // 32-बिट साइन किए गए पूर्णांक के लिए अधिकतम मान
20 if (timestamp > maxInt32) {
21 // आधुनिक जावास्क्रिप्ट में बहुत बड़े टाइमस्टैम्प के लिए BigInt का उपयोग करने पर विचार करें
22 console.warn("टाइमस्टैम्प 32-बिट पूर्णांक सीमा को पार करता है (Y2K38 समस्या)");
23 }
24
25 // सामान्य रूपांतरण के साथ आगे बढ़ें
26 try {
27 const date = new Date(timestamp * 1000);
28 const options = {
29 year: 'numeric',
30 month: 'long',
31 day: 'numeric',
32 weekday: 'long',
33 hour: use12Hour ? 'numeric' : '2-digit',
34 minute: '2-digit',
35 second: '2-digit',
36 hour12: use12Hour
37 };
38 return date.toLocaleString(undefined, options);
39 } catch (error) {
40 return "टाइमस्टैम्प को परिवर्तित करने में त्रुटि: " + error.message;
41 }
42}
43
संदर्भ
-
"यूनिक्स समय।" विकिपीडिया, विकिमीडिया फाउंडेशन, https://en.wikipedia.org/wiki/Unix_time
-
"2038 समस्या।" विकिपीडिया, विकिमीडिया फाउंडेशन, https://en.wikipedia.org/wiki/Year_2038_problem
-
ओल्सन, आर्थर डेविड। "कैलेंड्रिकल समय की जटिलताएँ।" द ओपन ग्रुप, https://www.usenix.org/legacy/events/usenix01/full_papers/olson/olson.pdf
-
"ISO 8601।" विकिपीडिया, विकिमीडिया फाउंडेशन, https://en.wikipedia.org/wiki/ISO_8601
-
"RFC 3339: इंटरनेट पर दिनांक और समय: टाइमस्टैम्प।" इंटरनेट इंजीनियरिंग टास्क फोर्स (IETF), https://tools.ietf.org/html/rfc3339
-
केर्निगन, ब्रायन W., और डेनिस M. रिची। "C प्रोग्रामिंग लैंग्वेज।" प्रेंटिस हॉल, 1988।
प्रतिक्रिया
इस उपकरण के बारे में प्रतिक्रिया देने के लिए प्रतिक्रिया टोस्ट पर क्लिक करें
संबंधित उपकरण
अधिक उपकरणों का पता लगाएँ जो आपके कार्यप्रवाह के लिए उपयोगी हो सकते हैं