我有一个相当简单的问题:我有一个看起来像这样的细胞载体:
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"。