在XP系统中 将区域语言选项中的短日期格式改成
再使用StrToDateTime转换时间 则处理会异常
示例:
procedure TForm1.btn2Click(Sender: TObject);
var
dateTimeStr,str1:String;
ADateTime:TDateTime;
begin
dateTimeStr := '2013-12-22 10:18:26';
ADateTime := StrToDateTime(dateTimeStr);
// str1 := DateTimeToStr(ADateTime);
str1 := FormatDateTime('yyyy-mm-dd HH:MM:SS',ADateTime);
ShowMessage(str1);
end;
由于短日期的格式改变,导致ADateTime得到的值为41630 时间部分缺失了,根本原因是StrToDateTime的默认用系统的短日期格式进行转换的 在解析HH:MM:SS
部分时,由于系统的短日期格式变成了yyyy-mm-dd ddd导致后面的时间解析异常
解决办法就是不用系统的短日期格式 而是用自定义的短日期格式
示例:
procedure TForm1.btn1Click(Sender: TObject);
var
dateTimeStr,str1:String;
ADateTime:TDateTime;
FSetting : TFormatSettings;
begin
//GetLocaleFormatSettings(GetUserDefaultLCID, FSetting);
FSetting.ShortDateFormat := 'yyyy-MM-dd';
FSetting.DateSeparator:='-';
FSetting.LongTimeFormat:='HH:MM:SS';
FSetting.TimeSeparator:=':';
dateTimeStr := '2013-12-22 10:18:26';
ADateTime := StrToDateTime(dateTimeStr,FSetting);
// str1 := DateTimeToStr(ADateTime);
str1 := FormatDateTime('yyyy-mm-dd HH:MM:SS',ADateTime);
ShowMessage(str1);
end;
这个时候再看ADateTime的值为41630.429468 日期时间解析正确