Mysql
 sql >> Datenbank >  >> RDS >> Mysql

So extrahieren Sie Datum und Uhrzeit aus einem String-Zeitstempel in Java

Verwenden Sie java.text.SimpleDateFormat und java.util.TimeZone

In welcher Zeitzone befindet sich die Datumszeichenfolge? Ersetzen Sie die folgende UTC Zeitzone mit dieser Zeitzone

SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
sdf.setTimeZone(TimeZone.getTimeZone("UTC"));
Date date = sdf.parse("2014-02-15 05:18:08");

SimpleDateFormat sdf2 = new SimpleDateFormat("dd-MM-yyyy hh:mm:ss a");
sdf2.setTimeZone(TimeZone.getTimeZone("IST"));
String dateStr = sdf2.format(date); // Output: 15-02-2014 10:48:08 AM

Hinweis: In welchem ​​Format ist die Stunde (24 Stunden/ 12 Stunden) in Ihrer Eingabezeichenfolge? Das obige Beispiel geht davon aus, dass es sich um ein 24-Stunden-Format handelt, da die Eingabezeichenfolge keine AM/PM-Informationen enthält.

Wenn die Eingabezeichenfolge auch im 12-Stunden-Format vorliegt, sollte Ihre Eingabezeichenfolge auch AM/PM-Informationen enthalten, z. B. 2014-02-15 05:18:08 PM . Ändern Sie in diesem Fall die sdf zu new SimpleDateFormat("yyyy-MM-dd hh:mm:ss a")

========================Bearbeitet: =====================

Um Ihre nächste Frage im Kommentar "So extrahieren Sie Datum und Uhrzeit separat" zu beantworten...

SimpleDateFormat sdfDate = new SimpleDateFormat("dd-MM-yyyy");
sdfDate.setTimeZone(java.util.TimeZone.getTimeZone("IST"));

SimpleDateFormat sdfTime = new SimpleDateFormat("hh:mm:ss a");
sdfTime.setTimeZone(java.util.TimeZone.getTimeZone("IST"));

String dateStr = sdfDate.format(date);
String timeStr = sdfTime.format(date);