日期编号转换失败,字符串格式'QQ-YYYY'



我有一个相当简单的问题:我有一个看起来像这样的细胞载体:

temp_y_date{1} = '2012Q2'
temp_y_date{2} = '2012Q1'
temp_y_date{3} = '2011Q4'

我想使用函数 datenum 将此单元格向量转换为日期向量。我最初将向量转换为"QQ-YYYY"格式,如下所示:

for i = 1:length(temp_y_date)
   temp = temp_y_date(i);
   year = cellfun(@(c) {c(1:4)}, temp);
   quarter = cellfun(@(c) {c(5:6)}, temp);
   temp_y_date(i) = strcat(quarter,'-',year);
end

temp_y_date的值现在是

temp_y_date (1) = 'Q2-2012'
temp_y_date (2) = 'Q1-2012'
temp_y_date (3) = 'Q4-2011'

我想我现在可以应用 datenum 函数:

temp_y_date = datenum(temp_y_date,'QQ-YYYY');

但是,我收到错误:

??? Error using ==> datenum at 178
DATENUM failed.
Caused by:
Error using ==> dtstr2dtnummx
Failed on converting date string to date number.

我在R2009b和R2012a上都进行了测试。您的代码适用于后者,但我在 R2009b 中收到相同的错误。

当我在temp_y_date中删除 Q 时,它在旧版本中得到了修复。因此,显然旧版本不接受四分之一的定义。

工作代码:

strdate = {'2012Q2', '2012Q1', '2011Q4'};
strdate2 = cellfun(@(c) strcat(c(6),'-',c(1:4)),strdate,'uni',false);
result = datenum(strdate2,'QQ-YYYY');

我更改了你的变量名称,因此调试更容易。还修复了带有cellfun的循环,您使用它的效率很低。我建议您了解单元格是什么,以及如何为它编制索引。

注意:如果您升级到另一个版本,或者其他人在更高版本中使用它,这将中断。所以如果你不想这样,我建议你使用 verLessThan 来区分不同版本的 matlab:

编辑:

help datenum

带有"Q"的格式不被 DATENUM 接受。

所以我想你必须自己升级或实现这个,虽然看起来并不难:

strdate = {'2012Q2', '2012Q1', '2011Q4'};
if verLessThan('matlab','7.12') % or maybe 7.11, it depends on which version the datenum functionality changed...
    strdate2 = cellfun(@(c) sprintf('%s/%02d/01',c(1:4),3*str2double(c(6))-2),strdate,'uni',false);
    result = datenum(strdate2,'YYYY/mm/dd');
else
    strdate2 = cellfun(@(c) strcat(c(5:6),'-',c(1:4)),strdate,'uni',false);
    result = datenum(strdate2,'QQ-YYYY');
end

如您所见,旧版本的 datenum 需要完整的日期规范:"YYYY/mm/dd"。

最新更新