我需要解析美国日期字符串以提取日期。
COleDateTime dData;
LCID lcid = 0x409; // 0x409 is the locale ID for English US
CString strDate;
dData.ParseDateTime("10/1/2014 9:43:00 AM", VAR_DATEVALUEONLY);
strDate = dData.Format(0, lcid);
我预计它会在 2014 年 10 月 1 日返回,但它会在 2014 年 10 月 10 日返回
有人可以告诉我我做错了什么吗?
最佳答案
我想您得到的是 10-Jan-2014,而不是 10-Oct-2014。除了您在不提供 lcid 参数的情况下进行解析(并使用 LANG_USER_DEFAULT
代替 - 请参阅另一个答案),解析代码使用 VarDateFromStr
,这反过来 - 大概 - 不会执行复杂的模式匹配而不是简单地请求 LOCALE_IDATE
语言环境的值。
您拥有的值 1(日-月-年)导致了这种值顺序。
LCID lcid = MAKELCID(MAKELANGID(LANG_ENGLISH, SUBLANG_ENGLISH_US), SORT_DEFAULT); // 0x409 is the locale ID for English US
TCHAR pszIDate[32] = { 0 };
ATLVERIFY(GetLocaleInfo(lcid, LOCALE_IDATE, pszIDate, _countof(pszIDate)) > 0);
_tprintf(_T("LOCALE_IDATE: %s\n"), pszIDate);
COleDateTime dData;
dData.ParseDateTime(_T("10/1/2014 9:43:00 AM"), VAR_DATEVALUEONLY, lcid); // LANG_USER_DEFAULT
_tprintf(_T("%s\n"), dData.Format(0, lcid));
dData.m_dt -= 1.0;
_tprintf(_T("%s\n"), dData.Format(0, lcid));
与(见“短日期”设置):
你得到:
LOCALE_IDATE: 1
10-Jan-14
09-Jan-14
与
你得到:
LOCALE_IDATE: 0
10/1/2014
9/30/2014
我想你应该避免使用这个遗留 API 解析日期/时间字符串,除非你只是在同一系统上从值格式化参数字符串。
关于C++ 在美国日期的 COleDateTime 中 LCID 的正确用法是什么,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27837094/