4

首先,我让用户输入他们自己的包含州、首都和人口的文本文件,然后我使用以下代码将所有这些值放入结构数组中:

clear
clc
%Part A
textfile=input('What is the name of your text file?\n','s');
fid=fopen(textfile);
file=textscan(fid,'%s %s %f','delimiter',',');
State=file{1}
Capital=file{2}
Population=file{3}
regions=struct('State',State,...
    'Capital',Capital,...
    'Population',Population)
fclose(fid);

我的第一个问题:是否可以显示结构中的所有?显示结构数组只是给了我这个:

50x1 struct array with fields:

    State
    Capital
    Population

我的第二个问题是:我是否可以通过尝试'California'仅查找来访问此结构中的信息?

4

1 回答 1

8

正如您已经发现的那样,MATLAB 中结构体数组的默认显示并不能告诉您太多信息,只是数组维度和字段名称。如果要查看内容,则必须自己创建格式化输出。一种方法是使用STRUCT2CELL收集单元格数组中的结构内容,然后使用FPRINTF以特定格式显示单元格内容。这是一个例子:

>> regions = struct('State',{'New York'; 'Ohio'; 'North Carolina'},...
                    'Capital',{'Albany'; 'Columbus'; 'Raleigh'},...
                    'Population',{97856; 787033; 403892});  %# Sample structure
>> cellData = struct2cell(regions);         %# A 3-by-3 cell array
>> fprintf('%15s (%s): %d\n',cellData{:});  %# Print the data
       New York (Albany): 97856
           Ohio (Columbus): 787033
 North Carolina (Raleigh): 403892

关于第二个问题,您可以从'State'单元格数组中的字段中收集条目,使用STRCMP将它们与给定名称进行比较以获取逻辑索引,然后获取相应的结构数组元素:

>> stateNames = {regions.State};            %# A 1-by-3 cell array of names
>> stateIndex = strcmp(stateNames,'Ohio');  %# Find the index for `Ohio`
>> stateData = regions(stateIndex)          %# Get the array element for `Ohio`

stateData = 

         State: 'Ohio'
       Capital: 'Columbus'
    Population: 787033

笔记:

正如您在评论中提到的,'Population'结构数组中的每个条目最终都包含整个 50×1 的人口数据向量。这可能是因为file{3}您的示例代码中包含一个向量,而file{1}file{2}包含元胞数组。为了将向量的内容正确地分布在file{3}结构数组的元素中,您需要将向量分解并使用NUM2CELL将每个值放在单元格数组的单独单元格中,然后再将其传递给STRUCT。像这样定义Population应该可以解决问题:

Population = num2cell(file{3});
于 2011-05-19T03:10:19.530 回答