2

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

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.
4

1 回答 1

0

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

当我将 Q 放入其中时,temp_y_date它已在旧版本中修复。所以显然旧版本不接受四分之一的定义。

工作代码:

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

DATENUM 不接受带有“Q”的格式。

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

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'。

于 2012-08-18T07:00:40.780 回答