യൂണിക്സ് ടൈംസ്റ്റാമ്പ് മുതൽ തീയതിയിലേക്ക് മാറ്റുന്ന ഉപകരണം: 12/24 മണിക്കൂർ ഫോർമാറ്റ് പിന്തുണ
യൂണിക്സ് ടൈംസ്റ്റാമ്പുകൾ മനുഷ്യൻ വായിക്കാവുന്ന തീയതികളിലും സമയങ്ങളിലും മാറ്റുക. ഈ ലളിതമായ, ഉപയോക്തൃ സൗഹൃദമുള്ള മാറ്റുന്ന ഉപകരണത്തിലൂടെ 12-മണിക്കൂർ, 24-മണിക്കൂർ സമയ ഫോർമാറ്റുകൾക്കിടയിൽ തിരഞ്ഞെടുക്കുക.
യൂണിക്സ് ടൈംസ്റ്റാമ്പ് കൺവെർട്ടർ
മാറ്റിയ തീയതി & സമയം
ഡോക്യുമെന്റേഷൻ
Unix Timestamp Converter
Introduction
Unix timestamp (പോസിക്സ് സമയം അല്ലെങ്കിൽ എപ്പോക് സമയം എന്നും അറിയപ്പെടുന്നു) ഒരു സമയത്തെ സൂചിപ്പിക്കുന്ന സിസ്റ്റമാണ്. ഇത് 1970 ജനുവരി 1 (മധ്യരാത്രി UTC/GMT) മുതൽ കഴിഞ്ഞ സെക്കൻഡുകളുടെ എണ്ണം ആണ്, ലീപ് സെക്കൻഡുകൾ കണക്കിലെടുക്കാതെ. Unix timestamps കമ്പ്യൂട്ടർ സിസ്റ്റങ്ങളിലെയും പ്രോഗ്രാമിംഗ് ഭാഷകളിലെയും വ്യാപകമായി ഉപയോഗിക്കുന്നു, കാരണം അവ ഒരു പ്രത്യേക സമയത്തെ സംക്ഷിപ്ത, ഭാഷാ സ്വതന്ത്രമായ പ്രതിനിധാനം നൽകുന്നു.
ഈ കൺവെർട്ടർ നിങ്ങൾക്ക് Unix timestamp-നെ മനുഷ്യ വായനയ്ക്ക് അനുയോജ്യമായ തീയതിയും സമയവും രൂപത്തിൽ മാറ്റാൻ അനുവദിക്കുന്നു. ഇത് 12-മണിക്കൂർ (AM/PM) കൂടാതെ 24-മണിക്കൂർ സമയരൂപങ്ങൾ പിന്തുണയ്ക്കുന്നു, വിവിധ പ്രാദേശികവും വ്യക്തിഗതവും മുൻഗണനകൾക്കായി.
How Unix Timestamps Work
Unix timestamps Unix Epoch (1970 ജനുവരി 1, 00:00:00 UTC) മുതൽ കഴിഞ്ഞ സെക്കൻഡുകളുടെ എണ്ണമായി കണക്കാക്കപ്പെടുന്നു. ഇത് സമയ വ്യത്യാസങ്ങൾ കണക്കാക്കുന്നതിനും തീയതികളെ സംക്ഷിപ്ത രൂപത്തിൽ സൂക്ഷിക്കുന്നതിനും പ്രത്യേകമായി പ്രയോജനകരമാണ്.
Unix timestamp-നെ കലണ്ടർ തീയതിയിലേക്ക് മാറ്റുന്നതിനുള്ള ഗണിതപരമായ പരിവർത്തനം ചില ഘട്ടങ്ങൾ ഉൾക്കൊള്ളുന്നു:
- Unix Epoch (1970 ജനുവരി 1, 00:00:00 UTC) എന്നതിൽ ആരംഭിക്കുക
- Timestamp-ൽ ഉള്ള സെക്കൻഡുകളുടെ എണ്ണം ചേർക്കുക
- ലീപ് വർഷങ്ങൾ, വ്യത്യസ്ത മാസങ്ങളുടെ നീളം, മറ്റ് കലണ്ടർ സങ്കീർണതകൾ എന്നിവ കണക്കിലെടുക്കുക
- ആവശ്യമായെങ്കിൽ സമയമേഖലയുടെ ക്രമീകരണങ്ങൾ പ്രയോഗിക്കുക
ഉദാഹരണത്തിന്, Unix timestamp 1609459200
വെള്ളിയാഴ്ച, 2021 ജനുവരി 1, 00:00:00 UTC-നെ പ്രതിനിധീകരിക്കുന്നു.
പരിവർത്തന ഫോർമുല ഇപ്രകാരം രേഖപ്പെടുത്താം:
അധികം പ്രോഗ്രാമിംഗ് ഭാഷകളും പ്രവർത്തനരീതികളും ഈ പരിവർത്തനം കൈകാര്യം ചെയ്യാൻ നിർമ്മിത ഫംഗ്ഷനുകൾ നൽകുന്നു, സങ്കീർണ്ണമായ കലണ്ടർ കണക്കുകൾ മറയ്ക്കുന്നു.
Time Format Options
ഈ കൺവെർട്ടർ രണ്ട് സമയരൂപങ്ങൾ നൽകുന്നു:
-
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-മണിക്കൂർ ഫോർമാറ്റ് അമേരിക്കൻ ഐക്യനാടുകൾ, കാനഡ, ഓസ്ട്രേലിയ, കൂടാതെ മറ്റ一些 ഇംഗ്ലീഷ് സംസാരിക്കുന്ന രാജ്യങ്ങളിൽ ദൈനംദിന ഉപയോഗത്തിന് വ്യാപകമാണ്.
Edge Cases and Limitations
Unix timestamps-നൊപ്പം പ്രവർത്തിക്കുമ്പോൾ, ചില എഡ്ജ് കേസുകളും പരിധികളും മനസ്സിലാക്കുന്നത് പ്രധാനമാണ്:
-
നഗറ്റീവ് ടൈംസ്റ്റാമ്പുകൾ: ഇവ Unix Epoch (1970 ജനുവരി 1) ന് മുമ്പുള്ള തീയതികളെ പ്രതിനിധീകരിക്കുന്നു. ഗണിതപരമായി സാധുവായതായിട്ടും, ചില സിസ്റ്റങ്ങൾ നെഗറ്റീവ് ടൈംസ്റ്റാമ്പുകൾ ശരിയായി കൈകാര്യം ചെയ്യില്ല.
-
2038 പ്രശ്നം: Unix timestamps സാധാരണയായി 32-ബിറ്റ് സൈൻഡ് ഇന്റേജർ ആയി സൂക്ഷിക്കുന്നു, ഇത് 2038 ജനുവരി 19-ന് ഓവർഫ്ലോ ചെയ്യും. ഈ സമയത്തിന് ശേഷം, 32-ബിറ്റ് സിസ്റ്റങ്ങൾ ശരിയായി സമയങ്ങൾ പ്രതിനിധീകരിക്കാൻ കഴിയില്ല, കൂടാതെ വലിയ ഇന്റേജർ തരം ഉപയോഗിച്ച് മാറ്റം വരുത്തേണ്ടതുണ്ട്.
-
അത്യന്തം വലിയ ടൈംസ്റ്റാമ്പുകൾ: വളരെ ദൂരമുള്ള ഭാവി തീയതികൾ ചില സിസ്റ്റങ്ങളിൽ പ്രതിനിധീകരിക്കാൻ കഴിയാത്തതായിരിക്കാം, അല്ലെങ്കിൽ അസംഗതമായി കൈകാര്യം ചെയ്യപ്പെടാം.
-
ലീപ് സെക്കൻഡുകൾ: Unix സമയം UTC-യുമായി സമന്വയിതമല്ല, കാരണം ഭൂമിയുടെ അസമാനമായ ചലനത്തെ പ്രതികാരം നൽകുന്നതിന് ലീപ് സെക്കൻഡുകൾ കാലയളവിൽ ചേർക്കുന്നു. അതിനാൽ Unix സമയം ആസ്ട്രോണമിക്കൽ സമയത്തോടൊപ്പം കൃത്യമായി സമന്വയിതമല്ല.
-
സമയം മേഖലയുടെ പരിഗണനകൾ: Unix timestamps UTC-യിൽ പ്രതിനിധീകരിക്കുന്നു. പ്രാദേശിക സമയത്തിലേക്ക് മാറ്റുന്നതിന് അധിക സമയം മേഖലയുടെ വിവരങ്ങൾ ആവശ്യമാണ്.
-
ദിവസം സംരക്ഷണ സമയം: ടൈംസ്റ്റാമ്പുകൾ പ്രാദേശിക സമയത്തിലേക്ക് മാറ്റുമ്പോൾ, ദിവസ സംരക്ഷണ സമയത്തിന്റെ സങ്കീർണതകൾ കണക്കിലെടുക്കണം.
Use Cases
Unix timestamps കമ്പ്യൂട്ടിംഗ്, ഡാറ്റാ മാനേജ്മെന്റ് എന്നിവയിൽ നിരവധി പ്രയോഗങ്ങളിൽ ഉപയോഗിക്കുന്നു:
-
ഡാറ്റാബേസ് റെക്കോർഡുകൾ: ടൈംസ്റ്റാമ്പുകൾ സാധാരണയായി എൻട്രികൾ എപ്പോൾ സൃഷ്ടിക്കപ്പെട്ടത് അല്ലെങ്കിൽ തിരുത്തപ്പെട്ടത് രേഖപ്പെടുത്താൻ ഉപയോഗിക്കുന്നു.
-
വെബ് വികസനം: HTTP ഹെഡറുകൾ, കുക്കികൾ, കാഷെ മെക്കാനിസങ്ങൾ സാധാരണയായി Unix timestamps ഉപയോഗിക്കുന്നു.
-
ലോഗ് ഫയലുകൾ: സിസ്റ്റം ലോഗുകൾ സാധാരണയായി സംഭവങ്ങൾ ക്രമീകരിക്കാൻ Unix timestamps ഉപയോഗിച്ച് രേഖപ്പെടുത്തുന്നു.
-
വർഷം നിയന്ത്രണ സിസ്റ്റങ്ങൾ: Git, മറ്റ് VCS-കൾ ടൈംസ്റ്റാമ്പുകൾ ഉപയോഗിച്ച് കമ്മിറ്റുകൾ എപ്പോൾ ഉണ്ടാക്കിയതെന്ന് രേഖപ്പെടുത്തുന്നു.
-
API പ്രതികരണങ്ങൾ: നിരവധി വെബ് API-കൾ അവരുടെ പ്രതികരണങ്ങളിൽ ടൈംസ്റ്റാമ്പുകൾ ഉൾക്കൊള്ളുന്നു, ഡാറ്റ എപ്പോൾ സൃഷ്ടിക്കപ്പെട്ടതെന്ന് അല്ലെങ്കിൽ റിസോഴ്സുകൾ എപ്പോൾ അവസാനമായി തിരുത്തപ്പെട്ടതെന്ന് സൂചിപ്പിക്കാൻ.
-
ഫയൽ സിസ്റ്റങ്ങൾ: ഫയൽ സൃഷ്ടി, തിരുത്തൽ സമയങ്ങൾ സാധാരണയായി Unix timestamps ആയി സൂക്ഷിക്കുന്നു.
-
സെഷൻ മാനേജ്മെന്റ്: വെബ് അപ്ലിക്കേഷനുകൾ ടൈംസ്റ്റാമ്പുകൾ ഉപയോഗിച്ച് ഉപയോക്തൃ സെഷനുകൾ എപ്പോൾ അവസാനിക്കേണ്ടതെന്ന് നിർണയിക്കുന്നു.
-
ഡാറ്റ വിശകലനം: ടൈംസ്റ്റാമ്പുകൾ വിശകലന അപ്ലിക്കേഷനുകളിൽ താത്പര്യസമയത്തെ കൈകാര്യം ചെയ്യാനുള്ള ഒരു മാനദണ്ഡമായാണ് ഉപയോഗിക്കുന്നത്.
Alternatives
Unix timestamps വ്യാപകമായി ഉപയോഗിക്കപ്പെടുമ്പോഴും, ചില സാഹചര്യങ്ങളിൽ കൂടുതൽ അനുയോജ്യമായ സമയ പ്രതിനിധാനം ഫോർമാറ്റുകൾ ഉണ്ട്:
-
ISO 8601: ഒരു മാനദണ്ഡിതമായ സ്ട്രിംഗ് ഫോർമാറ്റ് (ഉദാഹരണം: "2021-01-01T00:00:00Z") മനുഷ്യ വായനയ്ക്ക് അനുയോജ്യമായതും ക്രമീകരണയോഗ്യമായതും ആണ്. ഇത് ഡാറ്റ കൈമാറൽ, ഉപയോക്തൃ മുഖാമുഖം എന്നിവയ്ക്കായി കൂടുതൽ പ്രാധാന്യമർഹിക്കുന്നു.
-
RFC 3339: ഇന്റർനെറ്റ് പ്രോട്ടോകോളുകളിൽ ഉപയോഗിക്കുന്ന ISO 8601-ന്റെ ഒരു പ്രൊഫൈൽ, കൂടുതൽ കർശനമായ ഫോർമാറ്റിംഗ് ആവശ്യങ്ങൾക്കൊപ്പം.
-
മനുഷ്യ വായനയുള്ള ഫോർമാറ്റുകൾ: പ്രാദേശികമായ തീയതി സ്ട്രിംഗുകൾ (ഉദാഹരണം: "ജനുവരി 1, 2021") നേരിട്ട് ഉപയോക്തൃ ഇടപെടലുകൾക്കായി കൂടുതൽ അനുയോജ്യമാണ്, പക്ഷേ കണക്കാക്കലിന് കുറച്ച് അനുയോജ്യമായതല്ല.
-
മൈക്രോസോഫ്റ്റ് FILETIME: 1601 ജനുവരി 1 മുതൽ 100-നാനോസെക്കൻഡ് ഇടവേളകളുടെ എണ്ണം പ്രതിനിധീകരിക്കുന്ന 64-ബിറ്റ് മൂല്യം, വിൻഡോസ് സിസ്റ്റങ്ങളിൽ ഉപയോഗിക്കുന്നു.
-
ജൂലിയൻ ദിനം നമ്പർ: ജ്യോതിശാസ്ത്രം, ചില ശാസ്ത്രീയ പ്രയോഗങ്ങളിൽ ഉപയോഗിക്കുന്നു, 4713 BCE മുതൽ ദിവസങ്ങൾ എണ്ണുന്നു.
സമയം ഫോർമാറ്റിന്റെ തിരഞ്ഞെടുപ്പ് താഴെപ്പറയുന്ന ഘടകങ്ങൾക്കനുസരിച്ചാണ്:
- ആവശ്യമായ കൃത്യത
- മനുഷ്യ വായനയുടെ ആവശ്യങ്ങൾ
- സംഭരണ നിയന്ത്രണങ്ങൾ
- നിലവിലുള്ള സിസ്റ്റങ്ങളുമായി പൊരുത്തം
- പ്രതിനിധീകരിക്കേണ്ട തീയതികളുടെ പരിധി
History
Unix സമയത്തിന്റെ ആശയം Unix ഓപ്പറേറ്റിംഗ് സിസ്റ്റത്തിന്റെ വികസനത്തോടെ 1960-കളുടെ അവസാനം, 1970-കളുടെ ആരംഭത്തിൽ ബെൽ ലാബ്സിൽ ആരംഭിച്ചു. Epoch ആയി 1970 ജനുവരി 1-നെ ഉപയോഗിക്കാൻ തീരുമാനിക്കുന്നത് ഏതാണ്ട് അനധികൃതമായിരുന്നെങ്കിലും, ആ സമയത്ത് സംഭരണ ആവശ്യങ്ങൾ കുറയ്ക്കുന്നതിനും, എന്നാൽ ചരിത്രപരമായ ഡാറ്റയ്ക്കായി ഉപയോഗിക്കാൻ പ്രായോഗികമായിരുന്നു.
ആദ്യത്തെ നടപ്പാക്കലിൽ 32-ബിറ്റ് സൈൻഡ് ഇന്റേജർ ഉപയോഗിച്ച് കഴിഞ്ഞ സെക്കൻഡുകളുടെ എണ്ണം സൂക്ഷിക്കാൻ തീരുമാനിച്ചിരുന്നു, എന്നാൽ Unix സിസ്റ്റങ്ങളുടെ പ്രതീക്ഷിച്ച ജീവിതകാലത്തിനായി ഇത് മതിയായതായിരുന്നു. എന്നാൽ, ഈ തീരുമാനത്തിൽ 2038 പ്രശ്നം (കൂടാതെ "Y2K38" അല്ലെങ്കിൽ "Unix Millennium Bug" എന്നും അറിയപ്പെടുന്നു) ഉണ്ടാകുകയും, 32-ബിറ്റ് സൈൻഡ് ഇന്റേജർ 1970-01-01 മുതൽ 2038-01-19 വരെ മാത്രം തീയതികൾ പ്രതിനിധീകരിക്കാൻ കഴിയുമെന്നു വരും.
Unix, Unix-പോലെയുള്ള ഓപ്പറേറ്റിംഗ് സിസ്റ്റങ്ങൾ ജനപ്രിയത നേടുന്നതിനാൽ, Unix timestamp കമ്പ്യൂട്ടിങ്ങിൽ സമയത്തെ പ്രതിനിധീകരിക്കുന്ന ഒരു ഡിഫാക്ടോ സ്റ്റാൻഡേർഡ് ആയി മാറി. ഇത് നിരവധി പ്രോഗ്രാമിംഗ് ഭാഷകൾ, ഡാറ്റാബേസുകൾ, അപ്ലിക്കേഷനുകൾ എന്നിവയിൽ സ്വീകരിക്കപ്പെട്ടു, അതിന്റെ യഥാർത്ഥ Unix പരിസ്ഥിതിക്ക് പുറത്തേക്കും വ്യാപിച്ചു.
ആധുനിക സിസ്റ്റങ്ങൾ increasingly 64-ബിറ്റ് ഇന്റേജറുകൾ timestamps-നായി ഉപയോഗിക്കുന്നു, ഇത് Epoch-നിന്ന് 292 ബില്യൺ വർഷങ്ങൾക്കുള്ളിൽ പ്രതിനിധീകരിക്കാവുന്ന പരിധി വിപുലീകരിക്കുന്നു, 2038 പ്രശ്നം ഫലപ്രദമായി പരിഹരിക്കുന്നു. എന്നാൽ, പാരമ്പര്യ സിസ്റ്റങ്ങൾ, അപ്ലിക്കേഷനുകൾ ഇപ്പോഴും അപകടത്തിൽപ്പെട്ടേക്കാം.
Unix timestamp-ന്റെ ലളിതത്വവും ഉപയുക്തിയും അതിന്റെ തുടർച്ചയായ പ്രസക്തി ഉറപ്പുവരുത്തിയിട്ടുണ്ട്, കൂടുതൽ സങ്കീർണമായ സമയ പ്രതിനിധാനം ഫോർമാറ്റുകൾ വികസിപ്പിച്ചിട്ടും. ഇത് കമ്പ്യൂട്ടിങ്ങിലെ ഒരു അടിസ്ഥാന ആശയമായി തുടരുന്നു, നമ്മുടെ ഡിജിറ്റൽ അടിസ്ഥാനകെട്ടിടത്തിന്റെ അടിത്തറയെ അടയാളപ്പെടുത്തുന്നു.
Code Examples
Unix timestamps-നെ മനുഷ്യ വായനയ്ക്ക് അനുയോജ്യമായ തീയതികളിലേക്ക് മാറ്റുന്നതിനുള്ള വിവിധ പ്രോഗ്രാമിംഗ് ഭാഷകളിൽ ഉദാഹരണങ്ങൾ ഇവിടെ നൽകുന്നു:
1// JavaScript timestamp conversion
2function convertUnixTimestamp(timestamp, use12Hour = false) {
3 // Create a new Date object (JavaScript uses milliseconds)
4 const date = new Date(timestamp * 1000);
5
6 // Format options
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 // Convert to string using locale formatting
19 return date.toLocaleString(undefined, options);
20}
21
22// Example usage
23const timestamp = 1609459200; // January 1, 2021 00:00:00 UTC
24console.log(convertUnixTimestamp(timestamp, false)); // 24-hour format
25console.log(convertUnixTimestamp(timestamp, true)); // 12-hour format
26
1# Python timestamp conversion
2import datetime
3
4def convert_unix_timestamp(timestamp, use_12hour=False):
5 # Convert Unix timestamp to datetime object
6 date = datetime.datetime.fromtimestamp(timestamp)
7
8 # Format the date string
9 if use_12hour:
10 format_string = "%A, %B %d, %Y %I:%M:%S %p" # 12-hour format with AM/PM
11 else:
12 format_string = "%A, %B %d, %Y %H:%M:%S" # 24-hour format
13
14 return date.strftime(format_string)
15
16# Example usage
17timestamp = 1609459200 # January 1, 2021 00:00:00 UTC
18print(convert_unix_timestamp(timestamp, False)) # 24-hour format
19print(convert_unix_timestamp(timestamp, True)) # 12-hour format
20
1<?php
2// PHP timestamp conversion
3function convertUnixTimestamp($timestamp, $use12Hour = false) {
4 // Format string
5 $formatString = $use12Hour
6 ? 'l, F j, Y g:i:s A' // 12-hour format with AM/PM
7 : 'l, F j, Y H:i:s'; // 24-hour format
8
9 // Convert and format the date
10 return date($formatString, $timestamp);
11}
12
13// Example usage
14$timestamp = 1609459200; // January 1, 2021 00:00:00 UTC
15echo convertUnixTimestamp($timestamp, false) . "\n"; // 24-hour format
16echo convertUnixTimestamp($timestamp, true) . "\n"; // 12-hour format
17?>
18
1// Java timestamp conversion
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 // Convert Unix timestamp to Instant, then to LocalDateTime
10 Instant instant = Instant.ofEpochSecond(timestamp);
11 LocalDateTime dateTime = LocalDateTime.ofInstant(instant, ZoneId.systemDefault());
12
13 // Create formatter based on desired format
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 // Format the date
19 return dateTime.format(formatter);
20 }
21
22 public static void main(String[] args) {
23 long timestamp = 1609459200; // January 1, 2021 00:00:00 UTC
24 System.out.println(convertUnixTimestamp(timestamp, false)); // 24-hour format
25 System.out.println(convertUnixTimestamp(timestamp, true)); // 12-hour format
26 }
27}
28
1// C# timestamp conversion
2using System;
3
4class UnixTimestampConverter
5{
6 public static string ConvertUnixTimestamp(long timestamp, bool use12Hour)
7 {
8 // Convert Unix timestamp to DateTime
9 // Unix timestamp is seconds since 1970-01-01
10 DateTime dateTime = DateTimeOffset.FromUnixTimeSeconds(timestamp).DateTime;
11
12 // Format string based on 12-hour or 24-hour preference
13 string formatString = use12Hour
14 ? "dddd, MMMM d, yyyy h:mm:ss tt" // 12-hour format with AM/PM
15 : "dddd, MMMM d, yyyy HH:mm:ss"; // 24-hour format
16
17 // Return formatted date string
18 return dateTime.ToString(formatString);
19 }
20
21 static void Main()
22 {
23 long timestamp = 1609459200; // January 1, 2021 00:00:00 UTC
24 Console.WriteLine(ConvertUnixTimestamp(timestamp, false)); // 24-hour format
25 Console.WriteLine(ConvertUnixTimestamp(timestamp, true)); // 12-hour format
26 }
27}
28
1# Ruby timestamp conversion
2require 'time'
3
4def convert_unix_timestamp(timestamp, use_12hour = false)
5 # Convert Unix timestamp to Time object
6 time = Time.at(timestamp)
7
8 # Format based on 12-hour or 24-hour preference
9 if use_12hour
10 time.strftime("%A, %B %d, %Y %I:%M:%S %p") # 12-hour format with AM/PM
11 else
12 time.strftime("%A, %B %d, %Y %H:%M:%S") # 24-hour format
13 end
14end
15
16# Example usage
17timestamp = 1609459200 # January 1, 2021 00:00:00 UTC
18puts convert_unix_timestamp(timestamp, false) # 24-hour format
19puts convert_unix_timestamp(timestamp, true) # 12-hour format
20
1// Go timestamp conversion
2package main
3
4import (
5 "fmt"
6 "time"
7)
8
9func convertUnixTimestamp(timestamp int64, use12Hour bool) string {
10 // Convert Unix timestamp to Time
11 t := time.Unix(timestamp, 0)
12
13 // Format string based on 12-hour or 24-hour preference
14 formatString := "Monday, January 2, 2006 "
15 if use12Hour {
16 formatString += "3:04:05 PM" // 12-hour format with AM/PM
17 } else {
18 formatString += "15:04:05" // 24-hour format
19 }
20
21 // Return formatted time
22 return t.Format(formatString)
23}
24
25func main() {
26 timestamp := int64(1609459200) // January 1, 2021 00:00:00 UTC
27 fmt.Println(convertUnixTimestamp(timestamp, false)) // 24-hour format
28 fmt.Println(convertUnixTimestamp(timestamp, true)) // 12-hour format
29}
30
1// Swift timestamp conversion
2import Foundation
3
4func convertUnixTimestamp(_ timestamp: Int, use12Hour: Bool) -> String {
5 // Create Date from Unix timestamp
6 let date = Date(timeIntervalSince1970: TimeInterval(timestamp))
7
8 // Create DateFormatter
9 let formatter = DateFormatter()
10 formatter.dateStyle = .full
11
12 // Set time style based on 12-hour or 24-hour preference
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 // Return formatted date
23 return formatter.string(from: date)
24}
25
26// Example usage
27let timestamp = 1609459200 // January 1, 2021 00:00:00 UTC
28print(convertUnixTimestamp(timestamp, use12Hour: false)) // 24-hour format
29print(convertUnixTimestamp(timestamp, use12Hour: true)) // 12-hour format
30
1# R timestamp conversion
2convert_unix_timestamp <- function(timestamp, use_12hour = FALSE) {
3 # Convert Unix timestamp to POSIXct datetime
4 date_time <- as.POSIXct(timestamp, origin = "1970-01-01", tz = "UTC")
5
6 # Format based on 12-hour or 24-hour preference
7 if (use_12hour) {
8 format_string <- "%A, %B %d, %Y %I:%M:%S %p" # 12-hour format with AM/PM
9 } else {
10 format_string <- "%A, %B %d, %Y %H:%M:%S" # 24-hour format
11 }
12
13 # Return formatted date string
14 format(date_time, format_string)
15}
16
17# Example usage
18timestamp <- 1609459200 # January 1, 2021 00:00:00 UTC
19cat(convert_unix_timestamp(timestamp, FALSE), "\n") # 24-hour format
20cat(convert_unix_timestamp(timestamp, TRUE), "\n") # 12-hour format
21
1% MATLAB timestamp conversion
2function formattedDate = convertUnixTimestamp(timestamp, use12Hour)
3 % Convert Unix timestamp to MATLAB datetime
4 % Excel dates are days since 1900-01-01, with 1 = 1900-01-01
5 % Unix timestamps are seconds since 1970-01-01
6
7 % First convert to Excel date format
8 % 25569 is the number of days between 1900-01-01 and 1970-01-01
9 excelDate = (timestamp / 86400) + 25569;
10
11 % Format based on 12-hour or 24-hour preference
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% Example usage
20timestamp = 1609459200; % January 1, 2021 00:00:00 UTC
21disp(convertUnixTimestamp(timestamp, false)) % 24-hour format
22disp(convertUnixTimestamp(timestamp, true)) % 12-hour format
23
1' Excel VBA timestamp conversion
2Function ConvertUnixTimestamp(timestamp As Long, Optional use12Hour As Boolean = False) As String
3 ' Convert Unix timestamp to Excel date/time
4 ' Excel dates are days since 1900-01-01, with 1 = 1900-01-01
5 ' Unix timestamps are seconds since 1970-01-01
6
7 ' First convert to Excel date format
8 ' 25569 is the number of days between 1900-01-01 and 1970-01-01
9 Dim excelDate As Double
10 excelDate = (timestamp / 86400) + 25569
11
12 ' Format the date based on 12-hour or 24-hour preference
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' Usage in a worksheet:
21' =ConvertUnixTimestamp(1609459200, TRUE) ' 12-hour format
22' =ConvertUnixTimestamp(1609459200, FALSE) ' 24-hour format
23
Handling Edge Cases
Unix timestamps-നൊപ്പം പ്രവർത്തിക്കുമ്പോൾ, എഡ്ജ് കേസുകൾ ശരിയായി കൈകാര്യം ചെയ്യുന്നത് പ്രധാനമാണ്. ചില സാധാരണ എഡ്ജ് കേസുകൾ കൈകാര്യം ചെയ്യുന്നതിന്റെ ഉദാഹരണങ്ങൾ ഇവിടെ നൽകുന്നു:
1// JavaScript edge case handling
2function safeConvertTimestamp(timestamp, use12Hour = false) {
3 // Check if timestamp is valid
4 if (timestamp === undefined || timestamp === null || isNaN(timestamp)) {
5 return "അസാധുവായ ടൈംസ്റ്റാമ്പ്";
6 }
7
8 // Check for negative timestamps (dates before 1970)
9 if (timestamp < 0) {
10 // Some browsers might not handle negative timestamps correctly
11 // Use a more robust approach for dates before 1970
12 const date = new Date(timestamp * 1000);
13 if (isNaN(date.getTime())) {
14 return "അസാധുവായ തീയതി (1970-നു മുമ്പ്)";
15 }
16 }
17
18 // Check for Y2K38 problem (for 32-bit systems)
19 const maxInt32 = 2147483647; // Maximum value for 32-bit signed integer
20 if (timestamp > maxInt32) {
21 // Consider using BigInt for very large timestamps in modern JavaScript
22 console.warn("Timestamp exceeds 32-bit integer limit (Y2K38 issue)");
23 }
24
25 // Proceed with normal conversion
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
References
-
"Unix Time." Wikipedia, Wikimedia Foundation, https://en.wikipedia.org/wiki/Unix_time
-
"Year 2038 Problem." Wikipedia, Wikimedia Foundation, https://en.wikipedia.org/wiki/Year_2038_problem
-
Olson, Arthur David. "The Complexities of Calendrical Time." The Open Group, https://www.usenix.org/legacy/events/usenix01/full_papers/olson/olson.pdf
-
"ISO 8601." Wikipedia, Wikimedia Foundation, https://en.wikipedia.org/wiki/ISO_8601
-
"RFC 3339: Date and Time on the Internet: Timestamps." Internet Engineering Task Force (IETF), https://tools.ietf.org/html/rfc3339
-
Kernighan, Brian W., and Dennis M. Ritchie. "The C Programming Language." Prentice Hall, 1988.
പ്രതികരണം
ഈ ഉപകരണത്തെക്കുറിച്ച് പ്രതികരണം നൽകാൻ പ്രതികരണ ടോസ്റ്റിൽ ക്ലിക്ക് ചെയ്യുക
ബന്ധപ്പെട്ട ഉപകരണങ്ങൾ
നിങ്ങളുടെ പ്രവൃത്തി പ്രവാഹത്തിന് ഉപകാരപ്രദമായ കൂടുതൽ ഉപകരണങ്ങൾ കണ്ടെത്തുക