PostgreSQL
 sql >> Datenbank >  >> RDS >> PostgreSQL

Parsing-Datum mit verschiedenen Zeitzonen

Wenn ich das richtig verstehe, müssen Sie die Zeitzone für dasselbe Daten-/Kalenderobjekt festlegen, das Sie drucken. So:

private Locale locale = Locale.US;
private static final String[] tzStrings = {
    "America/New_York",
    "America/Chicago",
    "America/Denver",
    "America/Los_Angeles",
};

  Date now = new Date();
  for ( TimeZone z : zones) {
        DateFormat df = new SimpleDateFormat("K:mm a,z", locale);
        df.setTimeZone(z);
        String result = df.format(now);
        System.out.println(result); 
  }

Wenn ich die Zeitzone auf SimpleDateFormat setze, funktioniert es einwandfrei.

hier ist der Beispielcode...

String date="05/19/2008 04:30 AM (EST)";
SimpleDateFormat sdf = new SimpleDateFormat("MM/dd/yyyy hh:mm aaa (z)");
TimeZone.setDefault(TimeZone.getTimeZone("PST"));
long millis = sdf.parse(date).getTime();
sdf.setTimeZone(TimeZone.getDefault());
System.out.println(sdf.format(new Date(millis)));