你很亲密。我要做的是更改您的cellfun
调用,以便输出是单元格数组而不是数值数组。使用 'UniformOutput'
标志并将其设置为 0 或 false。
完成后,创建一个新的元胞数组,其中名称元胞数组和大小元胞数组相互堆叠。然后,您可以调用fprintf
一次。
% Save the names in a cell array
A = {myStructure.name};
% Save the sizes in another cell array
B = cellfun(@numel, {myStructure.data}, 'UniformOutput', 0);
% Create a master cell array where the first row are the names
% and the second row are the sizes
out = [A; B];
% Print out the elements side-by-side
fprintf('%s\t%d\n', out{:});
第三行代码的技巧是,当您使用 展开元胞数组时{:}
,这会创建一个以逗号分隔的列表,以列主要格式展开,这样做out{:}
实际上会给您:
A{1}, B{1}, A{2}, B{2}, ..., A{n}, B{n}
...它提供了您需要的交错。因此,提供此顺序fprintf
与指定的格式说明符一致,从而为您提供所需的内容。这就是为什么堆叠元胞数组很重要,这样每一列都可以提供您需要的信息。
小注
当然,永远不要忘记解决问题的最简单方法之一就是使用简单的for
循环。尽管for
循环被认为是不好的做法,但它们的性能在 MATLAB 的发展过程中已经取得了长足的进步。
简单地说,只需这样做:
for ii = 1 : numel(myStructure)
fprintf('%s\t%d\n', myStructure(ii).name, numel(myStructure(ii).data));
end
与我们上面对单元格数组所做的相比,上面的代码可以说更具可读性。您可以直接访问结构,而不必为了调用fprintf
一次而创建中间变量。
示例运行
这是这个运行的一个例子。使用如下所示的数据:
clear myStructure;
myStructure(1).name = 'hello';
myStructure(1).data = rand(5,1);
myStructure(2).name = 'hi';
myStructure(2).data = zeros(3,3);
myStructure(3).name = 'huh';
myStructure(3).data = ones(6,4);
运行打印代码后,我得到以下输出:
hello 5
hi 9
huh 24
我们可以看到大小是正确的,因为结构中的第一个元素只是一个随机的 5 元素向量,第二个元素是一个 3 x 3 = 9 个零矩阵,而最后一个元素是一个 6 x 4 = 24 个一个矩阵。