where in my code I am thinking wrong?

1 次查看(过去 30 天)
Manav Divekar
Manav Divekar 2021-11-29
评论: Jan 2021-11-30
I am trying to read data from the excel file, and return the age.
function [age] = xls_ageofperson (excelname, name)
[data text]= readtable(excelname);
ii=0;
jj=0;
for i = 1: length(data)
if string(name)==string(txt{1,i})
ii=i;
end
if (string(text)==string(txt{2,i}))
jj=i;
end
end
age = i;
if i input any name in the command window i am expecting it to return its age.

回答(1 个)

Jan
Jan 2021-11-29
  • length() is fragile: It uses to longer dimension. You cannot be sure if your table has more rows than columns. Use height() instead or size(data, 1) in older Matlab versions.
  • readtable has 1 output only So what do you expect text to be?
[data text]= readtable(excelname);
  • Your code replies the value of i as age, but the value of i comes from the last iteration of the loop:
age = i;
So age is always the number of rows of the table. But what are ii and jj good for?
I assume, you want:
function age = xls_ageofperson(excelname, name)
data = readtable(excelname);
age = data.age(data.name == name);
end
  2 个评论
Manav Divekar
Manav Divekar 2021-11-29
Error i am getting
>> [age] = xls_ageofperson('crps_data_fakenames.xlsx','Aniya Abbott')
Warning: Column headers from the file were modified to make them valid MATLAB
identifiers before creating variable names for the table. The original column headers
are saved in the VariableDescriptions property.
Set 'VariableNamingRule' to 'preserve' to use the original column headers as table
variable names.
Operator '==' is not supported for operands of type 'cell'.
Error in xls_ageofperson (line 4)
age = data.age(data.Name == Name);
Jan
Jan 2021-11-30
Okay. Does this mean that data.Name is a cell or Name? You can check this easily. Try this:
age = data.age(strcmp(data.Name, Name));

请先登录,再进行评论。

类别

Help CenterFile Exchange 中查找有关 Data Import from MATLAB 的更多信息

标签

产品


版本

R2021b

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by