Bonjour
J'ai une base de données ou j'ai un champ de type date-heure conserver avec le timezone de Paris soit 6 hrs de décalage avec nous. Comment faire afficher cette date-heure en timezone du Québec ? Il faut tenir compte de l'hrs avancé ou reculé (des fois on a que 5 hrs de décalage) et tous...
Par exemple: Si ma date dans la base de données est 2017-09-11 13hrs (hrs suisse) , je doit avoir obtenir comme résultat 2017-09-11 07h00 (hrs Québec)
Voici ce que j'ai fait mais j'ai que 5 hrs de décalage ça ne fonctionne pas. Quelqu'un peux m'aider
Merci!
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42 function TForm1.ConvertDatetime(pdtSuisse: TdateTime): TDateTime; var sysdt: TSystemTime; tZoneInfoQuebec: TTimeZoneInformation; begin GetTimeZoneInformation(tZoneInfoQuebec); tZoneInfoQuebec.Bias:= 300; {---Heure d'été -----------------} tZoneInfoQuebec.StandardBias:= 0; tZoneInfoQuebec.StandardDate.wYear:= 0; tZoneInfoQuebec.StandardDate.wMonth:= 11; tZoneInfoQuebec.StandardDate.wDay:= 1; tZoneInfoQuebec.StandardDate.wDayOfWeek:= 0; tZoneInfoQuebec.StandardDate.wHour:= 2; {---Heure d'Hiver ----------------} tZoneInfoQuebec.DaylightBias:= -60; tZoneInfoQuebec.DaylightDate.wYear:= 0; tZoneInfoQuebec.DaylightDate.wMonth:= 3; tZoneInfoQuebec.DaylightDate.wDay:= 2; tZoneInfoQuebec.DaylightDate.wDayOfWeek:= 0; tZoneInfoQuebec.DaylightDate.wHour:= 2; SysUtils.DateTimeToSystemTime(pdtSuisse,sysdt); SystemTimeToTzSpecificLocalTime(@tZoneInfoQuebec,sysdt , sysdt); Result := SysUtils.SystemTimeToDateTime(sysdt); end; procedure TForm1.Button1Click(Sender: TObject); Var dt1 :TDateTime; begin Memo1.Lines.Add(FormatDateTime('yyyy-mm-dd hh:nn',now)) ; dt1 := ConvertDatetime(now); FormatDateTime('yyyy-mm-dd hh:nn',dt1); Memo1.Lines.Add(FormatDateTime('yyyy-mm-dd hh:nn',dt1)) ; end;
Partager