रूपांतरण के लिए जावा स्ट्रिंग


886

जावा में Stringफॉर्मेट '2 जनवरी, 2010' में कन्वर्ट करने का सबसे अच्छा तरीका क्या है Date?

अंततः, मैं महीने, दिन और वर्ष को पूर्णांक के रूप में तोड़ना चाहता हूं ताकि मैं उपयोग कर सकूं

Date date = new Date();
date.setMonth()..
date.setYear()..
date.setDay()..
date.setlong currentTime = date.getTime();

तारीख को समय में बदलने के लिए।


15
ध्यान दें कि बहुत से उत्तर स्थान और टाइमज़ोन जैसी सूक्ष्मता को अनदेखा करते हैं। मैं उनमें से किसी का उपयोग करने से पहले दिनांक, कैलेंडर, टाइमज़ोन, लोकेल और SimpleDateFormat कक्षाओं के लिए दस्तावेज़ीकरण को करीब से पढ़ने की सलाह दूंगा।
क्रिस्टोफर जॉनसन जूल


7
जावा 8 एक नई तारीख / समय एपीआई प्रदान करता है। यदि आप जावा 8 (या नया) का उपयोग कर रहे हैं, तो आपको इस उत्तर पर एक नज़र
डालनी

2
सभी बाशिंदे वंचित Dateहैं।
रायडवल

5
FYI करें, जैसे परेशानी पुराने तिथि-समय कक्षाएं java.util.Date, java.util.Calendarऔर java.text.SimpleTextFormatअब कर रहे हैं विरासत , द्वारा का स्थान ले लिया java.time कक्षाएं। ओरेकल द्वारा ट्यूटोरियल देखें ।
बासिल बॉर्क

जवाबों:


1641

यह कठिन तरीका है, और उन java.util.Dateसेटर विधियों को जावा 1.1 (1997) के बाद से हटा दिया गया है। बस SimpleDateFormatइनपुट स्ट्रिंग से मेल खाते एक प्रारूप पैटर्न का उपयोग करके तारीख को प्रारूपित करें

इनपुट स्ट्रिंग के रूप में "2 जनवरी, 2010" के आपके विशिष्ट मामले में:

  1. "जनवरी" पूर्ण पाठ महीना है, इसलिए MMMMइसके लिए पैटर्न का उपयोग करें
  2. "2" महीने का छोटा दिन है, इसलिए dइसके लिए पैटर्न का उपयोग करें ।
  3. "2010" 4-अंकीय वर्ष है, इसलिए yyyyइसके लिए पैटर्न का उपयोग करें ।

String string = "January 2, 2010";
DateFormat format = new SimpleDateFormat("MMMM d, yyyy", Locale.ENGLISH);
Date date = format.parse(string);
System.out.println(date); // Sat Jan 02 00:00:00 GMT 2010

स्पष्ट Localeतर्क के महत्व पर ध्यान दें । यदि आप इसे छोड़ देते हैं, तो यह डिफ़ॉल्ट लोकेल का उपयोग करेगा जो जरूरी नहीं कि इनपुट स्ट्रिंग के महीने के नाम के रूप में उपयोग किया जाता है। यदि लोकेल इनपुट स्ट्रिंग के साथ मेल नहीं खाता है, तो आप भ्रामक रूप से तब java.text.ParseExceptionभी प्राप्त करेंगे जब प्रारूप पैटर्न वैध लगता है।

यहां सभी उपलब्ध प्रारूप पैटर्न को सूचीबद्ध करते हुए, javadoc से प्रासंगिकता का उद्धरण दिया गया है :

Letter  Date or Time Component  Presentation        Examples
------  ----------------------  ------------------  -------------------------------------
G       Era designator          Text                AD
y       Year                    Year                1996; 96
Y       Week year               Year                2009; 09
M/L     Month in year           Month               July; Jul; 07
w       Week in year            Number              27
W       Week in month           Number              2
D       Day in year             Number              189
d       Day in month            Number              10
F       Day of week in month    Number              2
E       Day in week             Text                Tuesday; Tue
u       Day number of week      Number              1
a       Am/pm marker            Text                PM
H       Hour in day (0-23)      Number              0
k       Hour in day (1-24)      Number              24
K       Hour in am/pm (0-11)    Number              0
h       Hour in am/pm (1-12)    Number              12
m       Minute in hour          Number              30
s       Second in minute        Number              55
S       Millisecond             Number              978
z       Time zone               General time zone   Pacific Standard Time; PST; GMT-08:00
Z       Time zone               RFC 822 time zone   -0800
X       Time zone               ISO 8601 time zone  -08; -0800; -08:00

ध्यान दें कि पैटर्न केस संवेदी होते हैं और चार वर्णों का पाठ आधारित पैटर्न या अधिक पूर्ण रूप का प्रतिनिधित्व करते हैं; यदि उपलब्ध हो तो अन्यथा संक्षिप्त या संक्षिप्त रूप का उपयोग किया जाता है। इसलिए उदा MMMMMया अधिक अनावश्यक है।

यहां SimpleDateFormatदिए गए स्ट्रिंग को तारीख तक पार्स करने के लिए मान्य पैटर्न के कुछ उदाहरण हैं :

Input string                            Pattern
------------------------------------    ----------------------------
2001.07.04 AD at 12:08:56 PDT           yyyy.MM.dd G 'at' HH:mm:ss z
Wed, Jul 4, '01                         EEE, MMM d, ''yy
12:08 PM                                h:mm a
12 o'clock PM, Pacific Daylight Time    hh 'o''clock' a, zzzz
0:08 PM, PDT                            K:mm a, z
02001.July.04 AD 12:08 PM               yyyyy.MMMM.dd GGG hh:mm aaa
Wed, 4 Jul 2001 12:08:56 -0700          EEE, d MMM yyyy HH:mm:ss Z
010704120856-0700                       yyMMddHHmmssZ
2001-07-04T12:08:56.235-0700            yyyy-MM-dd'T'HH:mm:ss.SSSZ
2001-07-04T12:08:56.235-07:00           yyyy-MM-dd'T'HH:mm:ss.SSSXXX
2001-W27-3                              YYYY-'W'ww-u

एक महत्वपूर्ण सूचना है कि है SimpleDateFormatहै नहीं सुरक्षित थ्रेड। दूसरे शब्दों में, आपको इसे कभी भी स्थिर या उदाहरण चर के रूप में घोषित और असाइन नहीं करना चाहिए और फिर इसे विभिन्न तरीकों / थ्रेड्स से पुन: उपयोग करना चाहिए। आपको इसे हमेशा स्थानीय स्कोप की विधि के भीतर नया बनाना चाहिए।


जावा 8 अपडेट

यदि आप जावा 8 या नए पर होते हैं, तो उपयोग करें DateTimeFormatter(यहां भी, सभी पूर्वनिर्धारित स्वरूप और उपलब्ध प्रारूप पैटर्न देखने के लिए लिंक पर क्लिक करें, ट्यूटोरियल यहां उपलब्ध है )। यह नया एपीआई JodaTime से प्रेरित है ।

String string = "January 2, 2010";
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("MMMM d, yyyy", Locale.ENGLISH);
LocalDate date = LocalDate.parse(string, formatter);
System.out.println(date); // 2010-01-02

नोट: यदि आपके फॉर्मेट पैटर्न में समय भाग भी शामिल है, तो LocalDateTime#parse(text, formatter)इसके बजाय का उपयोग करें LocalDate#parse(text, formatter)। और, यदि आपके प्रारूप पैटर्न में समय क्षेत्र भी शामिल है, तो ZonedDateTime#parse(text, formatter)इसके बजाय उपयोग करें ।

यहां सभी उपलब्ध प्रारूप पैटर्न को सूचीबद्ध करते हुए, javadoc से प्रासंगिकता का उद्धरण दिया गया है :

Symbol  Meaning                     Presentation  Examples
------  --------------------------  ------------  ----------------------------------------------
G       era                         text          AD; Anno Domini; A
u       year                        year          2004; 04
y       year-of-era                 year          2004; 04
D       day-of-year                 number        189
M/L     month-of-year               number/text   7; 07; Jul; July; J
d       day-of-month                number        10

Q/q     quarter-of-year             number/text   3; 03; Q3; 3rd quarter
Y       week-based-year             year          1996; 96
w       week-of-week-based-year     number        27
W       week-of-month               number        4
E       day-of-week                 text          Tue; Tuesday; T
e/c     localized day-of-week       number/text   2; 02; Tue; Tuesday; T
F       week-of-month               number        3

a       am-pm-of-day                text          PM
h       clock-hour-of-am-pm (1-12)  number        12
K       hour-of-am-pm (0-11)        number        0
k       clock-hour-of-am-pm (1-24)  number        0

H       hour-of-day (0-23)          number        0
m       minute-of-hour              number        30
s       second-of-minute            number        55
S       fraction-of-second          fraction      978
A       milli-of-day                number        1234
n       nano-of-second              number        987654321
N       nano-of-day                 number        1234000000

V       time-zone ID                zone-id       America/Los_Angeles; Z; -08:30
z       time-zone name              zone-name     Pacific Standard Time; PST
O       localized zone-offset       offset-O      GMT+8; GMT+08:00; UTC-08:00;
X       zone-offset 'Z' for zero    offset-X      Z; -08; -0830; -08:30; -083015; -08:30:15;
x       zone-offset                 offset-x      +0000; -08; -0830; -08:30; -083015; -08:30:15;
Z       zone-offset                 offset-Z      +0000; -0800; -08:00;

ध्यान दें कि अधिक लोकप्रिय पैटर्न के लिए इसके कई पूर्वनिर्धारित स्वरूप हैं । इसलिए उदाहरण के लिए DateTimeFormatter.ofPattern("EEE, d MMM yyyy HH:mm:ss Z", Locale.ENGLISH);, आप उपयोग कर सकते हैं DateTimeFormatter.RFC_1123_DATE_TIME। यह संभव है क्योंकि वे, इसके विपरीत SimpleDateFormat, धागा सुरक्षित हैं। यदि आवश्यक हो तो आप इस प्रकार अपना स्वयं का परिभाषित भी कर सकते हैं।

किसी विशेष इनपुट स्ट्रिंग प्रारूप के लिए, आपको एक स्पष्ट उपयोग करने की आवश्यकता नहीं है DateTimeFormatter: एक मानक आईएसओ 8601 दिनांक, जैसे 2016-09-26T17: 44: 57Z, सीधे सीधे पार्स किया जा सकता है LocalDateTime#parse(text)क्योंकि यह पहले से ही फॉर्मेटर का उपयोग करता है ISO_LOCAL_DATE_TIME। इसी तरह, LocalDate#parse(text)समय घटक (देखें ISO_LOCAL_DATE) के बिना एक आईएसओ तिथि ZonedDateTime#parse(text)पार्स करता है , और एक ऑफसेट और समय क्षेत्र जोड़ा (देखें ISO_ZONED_DATE_TIME) के साथ एक आईएसओ तिथि पार्स करता है ।


नमस्ते, विकल्प में O, UTC+08:00इसके बजाय इसे कैसे प्रिंट करने दें GMT+08:00। मुझे कोई उदाहरण नहीं मिला।
द गैंबलर

खजूर को पार्स करने के कई तरीके हैं, यहाँ DateFormat.parse के विभिन्न उपयोग के मामले हैं
drrw

हाय BalusC, मेरे पास एक स्ट्रिंग है 20-JUN-16 12.00.00.000000000 AM, इसे तिथि में बदलने के लिए मदद चाहिए। आपका सहयोग सराहनीय है!!
मैनडेयर जूल

@mannedear ओह सॉरी .. वो मेरी गलती थी। वैसे भी मुझे जवाब मिल गया है आप इसे यहाँ देख सकते हैं: stackoverflow.com/questions/50982310/…
क्वेन्डेवलपर्स

74

आह हाँ जावा तिथि चर्चा, फिर से। तिथि में हेरफेर से निपटने के लिए हम दिनांक , कैलेंडर , ग्रेगोरियन कैलेन्डर , और सिंपलडेटफॉर्म का उपयोग करते हैं । उदाहरण के लिए इनपुट के रूप में अपनी जनवरी की तारीख का उपयोग करें:

Calendar mydate = new GregorianCalendar();
String mystring = "January 2, 2010";
Date thedate = new SimpleDateFormat("MMMM d, yyyy", Locale.ENGLISH).parse(mystring);
mydate.setTime(thedate);
//breakdown
System.out.println("mydate -> "+mydate);
System.out.println("year   -> "+mydate.get(Calendar.YEAR));
System.out.println("month  -> "+mydate.get(Calendar.MONTH));
System.out.println("dom    -> "+mydate.get(Calendar.DAY_OF_MONTH));
System.out.println("dow    -> "+mydate.get(Calendar.DAY_OF_WEEK));
System.out.println("hour   -> "+mydate.get(Calendar.HOUR));
System.out.println("minute -> "+mydate.get(Calendar.MINUTE));
System.out.println("second -> "+mydate.get(Calendar.SECOND));
System.out.println("milli  -> "+mydate.get(Calendar.MILLISECOND));
System.out.println("ampm   -> "+mydate.get(Calendar.AM_PM));
System.out.println("hod    -> "+mydate.get(Calendar.HOUR_OF_DAY));

तो आप कुछ के साथ हेरफेर कर सकते हैं:

Calendar now = Calendar.getInstance();
mydate.set(Calendar.YEAR,2009);
mydate.set(Calendar.MONTH,Calendar.FEBRUARY);
mydate.set(Calendar.DAY_OF_MONTH,25);
mydate.set(Calendar.HOUR_OF_DAY,now.get(Calendar.HOUR_OF_DAY));
mydate.set(Calendar.MINUTE,now.get(Calendar.MINUTE));
mydate.set(Calendar.SECOND,now.get(Calendar.SECOND));
// or with one statement
//mydate.set(2009, Calendar.FEBRUARY, 25, now.get(Calendar.HOUR_OF_DAY), now.get(Calendar.MINUTE), now.get(Calendar.SECOND));
System.out.println("mydate -> "+mydate);
System.out.println("year   -> "+mydate.get(Calendar.YEAR));
System.out.println("month  -> "+mydate.get(Calendar.MONTH));
System.out.println("dom    -> "+mydate.get(Calendar.DAY_OF_MONTH));
System.out.println("dow    -> "+mydate.get(Calendar.DAY_OF_WEEK));
System.out.println("hour   -> "+mydate.get(Calendar.HOUR));
System.out.println("minute -> "+mydate.get(Calendar.MINUTE));
System.out.println("second -> "+mydate.get(Calendar.SECOND));
System.out.println("milli  -> "+mydate.get(Calendar.MILLISECOND));
System.out.println("ampm   -> "+mydate.get(Calendar.AM_PM));
System.out.println("hod    -> "+mydate.get(Calendar.HOUR_OF_DAY));

17
यह मत भूलो कि जनवरी महीने की संख्या है ... 0
निकोलस ज़ोलोल

50
String str_date = "11-June-07";
DateFormat formatter;
Date date;
formatter = new SimpleDateFormat("dd-MMM-yy");
date = formatter.parse(str_date);

13
घोषणाओं और परिभाषाओं को अलग करने का उद्देश्य क्या है (हालांकि पहले चर के लिए नहीं किया गया है)?
पीटर मोर्टेंसन

43

जावा 8 के साथ हमें एक नई तारीख / समय एपीआई ( जेएसआर 310 ) मिलता है।

निम्नलिखित तरीके का उपयोग जावा 8 में तारीख को पार्स करने के लिए किया जा सकता है, बिना जोडा-टाइम पर निर्भर किए :

 String str = "January 2nd, 2010";

// if we 2nd even we have changed in pattern also it is not working please workout with 2nd 
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("MMMM Q, yyyy", Locale.ENGLISH);
LocalDate date = LocalDate.parse(str, formatter);

// access date fields
int year = date.getYear(); // 2010
int day = date.getDayOfMonth(); // 2
Month month = date.getMonth(); // JANUARY
int monthAsInt = month.getValue(); // 1

लोकलडेट एक तारीख (समय के बिना) का प्रतिनिधित्व करने के लिए मानक जावा 8 वर्ग है। यदि आप उन मानों को पार्स करना चाहते हैं जिनमें दिनांक और समय की जानकारी होती है, तो आपको LocalDateTime का उपयोग करना चाहिए । टाइमज़ोन के मानों के लिए ZonedDateTime का उपयोग करें । दोनों parse()समान विधि प्रदान करते हैं LocalDate:

LocalDateTime dateWithTime = LocalDateTime.parse(strWithDateAndTime, dateTimeFormatter);
ZonedDateTime zoned = ZonedDateTime.parse(strWithTimeZone, zoneFormatter);

DateTimeFormatter Javadoc से वर्ण स्वरूपण सूची :

All letters 'A' to 'Z' and 'a' to 'z' are reserved as pattern letters. 
The following pattern letters are defined:

Symbol  Meaning                     Presentation      Examples
------  -------                     ------------      -------
 G       era                         text              AD; Anno Domini; A
 u       year                        year              2004; 04
 y       year-of-era                 year              2004; 04
 D       day-of-year                 number            189
 M/L     month-of-year               number/text       7; 07; Jul; July; J
 d       day-of-month                number            10

 Q/q     quarter-of-year             number/text       3; 03; Q3; 3rd quarter
 Y       week-based-year             year              1996; 96
 w       week-of-week-based-year     number            27
 W       week-of-month               number            4
 E       day-of-week                 text              Tue; Tuesday; T
 e/c     localized day-of-week       number/text       2; 02; Tue; Tuesday; T
 F       week-of-month               number            3

 a       am-pm-of-day                text              PM
 h       clock-hour-of-am-pm (1-12)  number            12
 K       hour-of-am-pm (0-11)        number            0
 k       clock-hour-of-am-pm (1-24)  number            0

 H       hour-of-day (0-23)          number            0
 m       minute-of-hour              number            30
 s       second-of-minute            number            55
 S       fraction-of-second          fraction          978
 A       milli-of-day                number            1234
 n       nano-of-second              number            987654321
 N       nano-of-day                 number            1234000000

 V       time-zone ID                zone-id           America/Los_Angeles; Z; -08:30
 z       time-zone name              zone-name         Pacific Standard Time; PST
 O       localized zone-offset       offset-O          GMT+8; GMT+08:00; UTC-08:00;
 X       zone-offset 'Z' for zero    offset-X          Z; -08; -0830; -08:30; -083015; -08:30:15;
 x       zone-offset                 offset-x          +0000; -08; -0830; -08:30; -083015; -08:30:15;
 Z       zone-offset                 offset-Z          +0000; -0800; -08:00;

अंश का दूसरा काम कैसे पूरा करता है? यदि मैं LocalDateTime दिनांक = LocalDateTime.parse ("20140920111713000", DateTimeFormatter.ofh प्रतिमान ("yyyyMMddHHm mssSSS") का उपयोग करता हूं; यह विफल हो जाता है, लेकिन अगर मैं LocalDateTime दिनांक = LocalDateTime.parse ("20140920111713.000", DateTimeFormatter.o fPattern ("yyyyMMddHH mts .SSS") का उपयोग करता हूं; यह काम करता है
reos

27

जबकि कुछ उत्तर तकनीकी रूप से सही हैं, वे उचित नहीं हैं।

  • Java.util.Date और कैलेंडर कक्षाएं बेहद कष्टकारी हैं। डिजाइन और कार्यान्वयन में खामियों के कारण, उनसे बचें। सौभाग्य से हमारे पास दो अन्य उत्कृष्ट तिथि-समय पुस्तकालयों की हमारी पसंद है:
    • Joda-Time
      इस लोकप्रिय ओपन-सोर्स फ्री-कॉस्ट लाइब्रेरी का उपयोग जावा के कई संस्करणों में किया जा सकता है। इसके उपयोग के कई उदाहरण StackOverflow पर पाए जा सकते हैं। इनमें से कुछ को पढ़ने से आपको जल्दी गति प्राप्त करने में मदद मिलेगी।
    • java.time। * पैकेज
      , कक्षाओं का यह नया सेट जोडा-टाइम से प्रेरित है और JSR 310 द्वारा परिभाषित किया गया है। इन वर्गों को जावा 8 में बनाया गया है। इन कक्षाओं को जावा 7 में वापस करने के लिए एक परियोजना पर काम चल रहा है, लेकिन यह बैकपोर्टिंग द्वारा समर्थित नहीं है आकाशवाणी।
  • क्रिस्टोफर जॉनसन ने इस सवाल पर अपनी टिप्पणी में सही ढंग से उल्लेख किया, अन्य उत्तर महत्वपूर्ण मुद्दों की उपेक्षा करते हैं:
    • डे
      डेट के समय में एक तारीख का भाग और एक दिन का भाग दोनों होते हैं)
    • समय क्षेत्र
      दिन की शुरुआत समय क्षेत्र पर निर्भर करती है। यदि आप समय क्षेत्र निर्दिष्ट करने में विफल रहते हैं, तो JVM का डिफ़ॉल्ट समय क्षेत्र लागू होता है। इसका मतलब है कि अन्य कंप्यूटरों पर या संशोधित समय क्षेत्र सेटिंग के साथ आपके कोड का व्यवहार बदल सकता है। शायद नहीं जो आप चाहते हैं।
    • लोकेल
      लोकेल की भाषा निर्दिष्ट करती है कि पार्सिंग के दौरान आए शब्दों (महीने का नाम और दिन) की व्याख्या कैसे करें। ( BalusC द्वारा उत्तर इसे ठीक से संभालता है।) साथ ही, आपकी तिथि-समय का एक स्ट्रिंग प्रतिनिधित्व उत्पन्न करते समय कुछ प्रारूपकों के उत्पादन को प्रभावित करता है।

Joda समय

जोडा-टाइम फॉलो के बारे में कुछ नोट्स।

समय क्षेत्र

में Joda समय , एक दिनांक समय वस्तु सही मायने में अपने आप ही सौंपा समय क्षेत्र को जानता है। यह java.util.Date वर्ग जो विरोधाभासों लगता है एक समय क्षेत्र के लिए, लेकिन नहीं करता है।

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

चूँकि आपके इनपुट स्ट्रिंग में कोई समय भाग नहीं है, इसलिए Joda-Time दिन के रूप में निर्दिष्ट समय क्षेत्र के दिन के पहले क्षण को निर्दिष्ट करता है। आमतौर पर इसका मतलब है, 00:00:00लेकिन हमेशा नहीं, डेलाइट सेविंग टाइम (डीएसटी) या अन्य विसंगतियों के कारण। वैसे, आप कॉल करके किसी भी DateTime उदाहरण के लिए एक ही कर सकते हैं withTimeAtStartOfDay

प्रारूप पैटर्न

एक फॉर्मैटर पैटर्न में उपयोग किए गए वर्ण, joda.util.Date/Calendar में समान हैं, लेकिन वास्तव में समान नहीं हैं। डॉक्स को ध्यान से पढ़ें।

अचल स्थिति

हम आमतौर पर जोडा-टाइम में अपरिवर्तनीय कक्षाओं का उपयोग करते हैं। किसी मौजूदा दिनांक-समय ऑब्जेक्ट को संशोधित करने के बजाय, हम उन विधियों को कॉल करते हैं जो अन्य ऑब्जेक्ट के आधार पर एक नया ताज़ा उदाहरण बनाते हैं, जिसमें कॉपी किए गए अधिकांश पहलुओं को छोड़कर जहां परिवर्तन वांछित थे। एक उदाहरण withZoneनीचे अंतिम पंक्ति में कॉल है । अपरिवर्तनशीलता जोडा-टाइम को बहुत सुरक्षित बनाने में मदद करती है, और कुछ काम को और अधिक स्पष्ट भी कर सकती है।

रूपांतरण

आपको java.util की आवश्यकता होगी। अन्य वर्गों / ढांचे के साथ उपयोग के लिए ऑब्जेक्ट्स जो कि Joda-Time ऑब्जेक्ट्स के बारे में नहीं जानते हैं। सौभाग्य से, आगे-पीछे करना बहुत आसान है।

एक java.util.Date ऑब्जेक्ट (यहाँ नाम date) से Joda-Time DateTime पर जा रहे हैं…

org.joda.time.DateTime dateTime = new DateTime( date, timeZone );

Joda-Time से java.util.Date ऑब्जेक्ट पर दूसरी दिशा में जा रहे हैं ...

java.util.Date date = dateTime.toDate();

नमूना कोड

String input = "January 2, 2010";

java.util.Locale locale = java.util.Locale.US;
DateTimeZone timeZone = DateTimeZone.forID( "Pacific/Honolulu" ); // Arbitrarily chosen for example.
DateTimeFormatter formatter = DateTimeFormat.forPattern( "MMMM d, yyyy" ).withZone( timeZone ).withLocale( locale );
DateTime dateTime = formatter.parseDateTime( input );

System.out.println( "dateTime: " + dateTime );
System.out.println( "dateTime in UTC/GMT: " + dateTime.withZone( DateTimeZone.UTC ) );

जब चला…

dateTime: 2010-01-02T00:00:00.000-10:00
dateTime in UTC/GMT: 2010-01-02T10:00:00.000Z

20

SimpleDateFormat वर्ग के साथ काम करते समय, यह याद रखना महत्वपूर्ण है कि दिनांक थ्रेड-सुरक्षित नहीं है और आप एकाधिक थ्रेड्स के साथ एक एकल दिनांक ऑब्जेक्ट साझा नहीं कर सकते।

इसके अलावा "एम" और "एम" के बीच बड़ा अंतर है जहां छोटे मामले का उपयोग मिनटों के लिए किया जाता है और महीने के लिए पूंजी मामले का उपयोग किया जाता है। "डी" और "डी" के साथ भी ऐसा ही है। यह सूक्ष्म कीड़े पैदा कर सकता है जो अक्सर अनदेखी हो जाती है। देखें जावाडोक या गाइड जावा में दिनांक को स्ट्रिंग में कनवर्ट करने के लिए अधिक जानकारी के लिए।


1
इस मी / एम अंतर से मुझे 5 मिनट की निराशा हुई, इसे इंगित करने के लिए धन्यवाद :)
भैंस

मुझे आश्चर्य है कि किसी और ने इसका उल्लेख नहीं किया। SimpleDateFormat का उपयोग वेब अनुप्रयोगों (या किसी भी अन्य बहु-थ्रेडेड ऐप) में करना एक बड़ी संख्या है। Java 7 के माध्यम से, मैं "FastDateFormat" का उपयोग कर रहा हूं।
जैकएलथॉर्नटन

18
DateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
Date date;
try {
    date = dateFormat.parse("2013-12-4");
    System.out.println(date.toString()); // Wed Dec 04 00:00:00 CST 2013

    String output = dateFormat.format(date);
    System.out.println(output); // 2013-12-04
} 
catch (ParseException e) {
    e.printStackTrace();
}

यह मेरे लिए ठीक काम करता है।


5
यह बुध दिसंबर 04 00:00:00 जीएसटी 2013 को आउटपुट के रूप में वापस नहीं करेगा 2013-12-04
शम्स

ParseException try / catch में लिपटे रहना चाहिए
svarog

यह अभिप्रेत मूल्यों को आशा के अनुरूप नहीं लौटाता है। कृपया सलाह देने से पहले परीक्षण करें
जीवनकाल

7

आप स्ट्रिंग को अद्यतन करने के लिए SimpleDateformat का उपयोग कर सकते हैं

SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
String strDate = "2000-01-01";
Date date = new Date(sdf.parse(strDate).getTime());


1
SimpleDateFormat पार्स विधि एक दिनांक ऑब्जेक्ट देता है। फिर दिनांक निर्माणकर्ता का उपयोग क्यों करें?
nespapu

6

इसके अलावा, SimpleDateFormat GWT जैसी क्लाइंट साइड तकनीकों में से कुछ के साथ उपलब्ध नहीं है ।

Calendar.getInstance () के लिए जाना एक अच्छा विचार है, और आपकी आवश्यकता दो तिथियों की तुलना करने की है; लंबी तारीख के लिए जाओ।


6

सरल दो स्वरूपक हमने उपयोग किए हैं:

  1. हमें कौन सी प्रारूप तिथि चाहिए?
  2. कौन सी प्रारूप तिथि वास्तव में मौजूद है?

हम समय प्रारूप के लिए पूर्ण तिथि पार्स करते हैं:

date="2016-05-06 16:40:32";

public static String setDateParsing(String date) throws ParseException {

    // This is the format date we want
    DateFormat mSDF = new SimpleDateFormat("hh:mm a");

    // This format date is actually present
    SimpleDateFormat formatter = new SimpleDateFormat("yyyy-mm-dd hh:mm");
    return mSDF.format(formatter.parse(date));
}

5

मेरा विनम्र परीक्षण कार्यक्रम। मैं इसे फ़ॉर्मैटर और लुक-अप लंबी तिथियों के साथ खेलने के लिए उपयोग करता हूं जो मुझे लॉग-फाइल में मिलते हैं (लेकिन जिन्होंने उन्हें वहां रखा है ...)।

मेरा परीक्षण कार्यक्रम:

package be.test.package.time;

import java.text.DateFormat;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import java.util.TimeZone;

public class TimeWork {

    public static void main(String[] args) {    

        TimeZone timezone = TimeZone.getTimeZone("UTC");

        List<Long> longs = new ArrayList<>();
        List<String> strings = new ArrayList<>();

        //Formatting a date needs a timezone - otherwise the date get formatted to your system time zone.
        //Use 24h format HH. In 12h format hh can be in range 0-11, which makes 12 overflow to 0.
        DateFormat formatter = new SimpleDateFormat("dd-MM-yyyy HH:mm:ss.SSS");
        formatter.setTimeZone(timezone);

        Date now = new Date();

        //Test dates
        strings.add(formatter.format(now));
        strings.add("01-01-1970 00:00:00.000");
        strings.add("01-01-1970 00:00:01.000");
        strings.add("01-01-1970 00:01:00.000");
        strings.add("01-01-1970 01:00:00.000");
        strings.add("01-01-1970 10:00:00.000");
        strings.add("01-01-1970 12:00:00.000");
        strings.add("01-01-1970 24:00:00.000");
        strings.add("02-01-1970 00:00:00.000");
        strings.add("01-01-1971 00:00:00.000");
        strings.add("01-01-2014 00:00:00.000");
        strings.add("31-12-1969 23:59:59.000");
        strings.add("31-12-1969 23:59:00.000");
        strings.add("31-12-1969 23:00:00.000");

        //Test data
        longs.add(now.getTime());
        longs.add(-1L);
        longs.add(0L); //Long date presentation at - midnight 1/1/1970 UTC - The timezone is important!
        longs.add(1L);
        longs.add(1000L);
        longs.add(60000L);
        longs.add(3600000L);
        longs.add(36000000L);
        longs.add(43200000L);
        longs.add(86400000L);
        longs.add(31536000000L);
        longs.add(1388534400000L);
        longs.add(7260000L);
        longs.add(1417706084037L);
        longs.add(-7260000L);

        System.out.println("===== String to long =====");

        //Show the long value of the date
        for (String string: strings) {
            try {
                Date date = formatter.parse(string);
                System.out.println("Formated date : " + string + " = Long = " + date.getTime());
            } catch (ParseException e) {
                e.printStackTrace();
            }
        }

        System.out.println("===== Long to String =====");

        //Show the date behind the long
        for (Long lo : longs) {
            Date date = new Date(lo);
            String string = formatter.format(date);
            System.out.println("Formated date : " + string + " = Long = " + lo);        
        }
    }
}

परीक्षण के परिणाम:

===== String to long =====
Formated date : 05-12-2014 10:17:34.873 = Long = 1417774654873
Formated date : 01-01-1970 00:00:00.000 = Long = 0
Formated date : 01-01-1970 00:00:01.000 = Long = 1000
Formated date : 01-01-1970 00:01:00.000 = Long = 60000
Formated date : 01-01-1970 01:00:00.000 = Long = 3600000
Formated date : 01-01-1970 10:00:00.000 = Long = 36000000
Formated date : 01-01-1970 12:00:00.000 = Long = 43200000
Formated date : 01-01-1970 24:00:00.000 = Long = 86400000
Formated date : 02-01-1970 00:00:00.000 = Long = 86400000
Formated date : 01-01-1971 00:00:00.000 = Long = 31536000000
Formated date : 01-01-2014 00:00:00.000 = Long = 1388534400000
Formated date : 31-12-1969 23:59:59.000 = Long = -1000
Formated date : 31-12-1969 23:59:00.000 = Long = -60000
Formated date : 31-12-1969 23:00:00.000 = Long = -3600000
===== Long to String =====
Formated date : 05-12-2014 10:17:34.873 = Long = 1417774654873
Formated date : 31-12-1969 23:59:59.999 = Long = -1
Formated date : 01-01-1970 00:00:00.000 = Long = 0
Formated date : 01-01-1970 00:00:00.001 = Long = 1
Formated date : 01-01-1970 00:00:01.000 = Long = 1000
Formated date : 01-01-1970 00:01:00.000 = Long = 60000
Formated date : 01-01-1970 01:00:00.000 = Long = 3600000
Formated date : 01-01-1970 10:00:00.000 = Long = 36000000
Formated date : 01-01-1970 12:00:00.000 = Long = 43200000
Formated date : 02-01-1970 00:00:00.000 = Long = 86400000
Formated date : 01-01-1971 00:00:00.000 = Long = 31536000000
Formated date : 01-01-2014 00:00:00.000 = Long = 1388534400000
Formated date : 01-01-1970 02:01:00.000 = Long = 7260000
Formated date : 04-12-2014 15:14:44.037 = Long = 1417706084037
Formated date : 31-12-1969 21:59:00.000 = Long = -7260000

2

स्रोत लिंक

के लिए एंड्रॉयड

Calendar.getInstance ()। GetTime () देता है

Thu Jul 26 15:54:13 GMT+05:30 2018

उपयोग

String oldDate = "Thu Jul 26 15:54:13 GMT+05:30 2018";
DateFormat format = new SimpleDateFormat("EEE LLL dd HH:mm:ss Z yyyy");
Date updateLast = format.parse(oldDate);

0

स्ट्रिंग टू डेट रूपांतरण:

private Date StringtoDate(String date) throws Exception {
            SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy-MM-dd");
            java.sql.Date sqlDate = null;
            if( !date.isEmpty()) {

                try {
                    java.util.Date normalDate = sdf1.parse(date);
                    sqlDate = new java.sql.Date(normalDate.getTime());
                } catch (ParseException e) {
                    throw new Exception("Not able to Parse the date", e);
                }
            }
            return sqlDate;
        }

-1

इसे इस्तेमाल करे

String date = get_pump_data.getString("bond_end_date");
DateFormat format = new SimpleDateFormat("yyyy-MM-dd", Locale.ENGLISH);
Date datee = (Date)format.parse(date);
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.