一次设置多个字段/将新字段添加到单元格结构

时间:2013-02-14 08:44:16

标签: matlab octave

我有1xn结构。结构包含一些带有数字单元格的字段。并非每个结构都具有相同的字段。所以我想将缺少的字段添加到结构中。但我没有得到它。

%  Mimimal example
%  I have same cells, imported from csv by csv2cell()

clear

dataCell{1}={"field_a","field_b","field_c"; ...
    1,2,3; ...
    4,5,6};

dataCell{2}={"field_a","field_b","field_d"; ...
    1,2,4; ...
    4,5,8};

%   Then I convert them to a struct
for ii=1:numel(dataCell)    
DataStruct{ii}=cell2struct((dataCell{ii}(2:end,:)),[dataCell{ii}(1,:)],2);
  try fields=[fields, fieldnames(DataStruct{ii})']; % fails for the first loop, because 'fields' doesn't exist yet
  catch
   fields=[fieldnames(DataStruct{ii})']; % create 'fields' in the first loop
  end
end

% Create a list of all existing fields
fields=unique(fields);

% Now look for the missing fields and add them to the struct
for jj=1:numel(DataStruct)
  missing_fields{jj} = setdiff(fields,fieldnames(DataStruct{jj}));
  for kk=1:numel(missing_fields)
    DataStruct{jj}.(missing_fields{jj}{kk})=NaN*zeros(numel(dataCell{jj}(2:end,1)),1); % Execution fails here!
  end
end

这会导致错误:

八度错误

error: invalid assignment to cs-list outside multiple assignment
error: called from:
error:   ~/example.m at line 29, column 44

Matlab错误

Insufficient outputs from right hand side to satisfy comma separated
list expansion on left hand side.  Missing [] are the most likely cause.

问题是,DataStruct{1}.field_a的输出不是矩阵或单元格,而是多个ans。是否有可能将细胞转换为矩阵或更好地导入csv?

另一个好的可能性就是这样的

 DataStruct{jj}=setfields(missing_fields{jj},NaN_Values{jj})

其中missing_fields{jj}NaN_Values都是具有相同长度的单元格,因此我可以一次设置多个字段。

2 个答案:

答案 0 :(得分:2)

在您的上一个question之后 - 您可以使用交易命令。

段:

a=struct('f1',num2cell(1:10))
missing_field = 'test'
[a.(missing_field)]=deal(NaN)

答案 1 :(得分:2)

使用deal函数将输出分配给输入。以你的例子:

% Now look for the missing fields and add them to the struct
for jj=1:numel(DataStruct)
  missing_fields{jj} = setdiff(fields,fieldnames(DataStruct{jj}));
  for kk=1:numel(missing_fields)
    [DataStruct{jj}.(missing_fields{jj}{kk})] = deal(NaN*zeros(numel(dataCell{jj}(2:end,1)),1));
  end
end

请注意,您将获得Index exceeds matrix dimensions,但这是由于一个不同的问题 - 我相信您可以将其排序!