Using string compare on imported data

조회 수: 1 (최근 30일)
Jacob Barrett-Newton
Jacob Barrett-Newton 2018년 2월 11일
댓글: Jacob Barrett-Newton 2018년 2월 11일
I am very new to Matlab and have only ever used maple. I am trying to use string compare on huge imported data (26,000 rows) to a specific word to find the row that contains it.
I understand the basics of strcmp and can use it within matlab, but cannot figure out how to use it for a data set. So for example, I am currently working with the code:
s1 = 'RT'; s2 = {ImpD(:,4)}; TF = strcmp(s1, s2); find(TF);
ImpD(:,4) since I am looking for the specific text in the 4th column. I just don't think Matlab is realizing I am referencing the imported data. How can i fix this?
  댓글 수: 6
Guillaume
Guillaume 2018년 2월 11일
Is it string or char array? People use the two interchangeably but they are actually two very different types. comparisons are easier with strings.
Since ImpD is a table, what is the name of the fourth column?
Jacob Barrett-Newton
Jacob Barrett-Newton 2018년 2월 11일
Well now that i have imported it as a string array, class(ImpD) returns string and class(ImpD{1, 4}) returns char

댓글을 달려면 로그인하십시오.

채택된 답변

Guillaume
Guillaume 2018년 2월 11일
If ImpD is a string array with a least four columns:
ismatch = ImpD(:, 4) == "RT"
to find "RT" in the fourth column.
If it were a table as you had initially:
ismatch = ImpD{:, 4} == "RT"
%or
ismatch = ImpD.column4name == "RT" %replace column4name by actual name
If you're going to wrap the above in a loop to find different strings and do something then it is very likely that there is a much better way. A better explanation of what you want to achieve and of the starting point would be required.
  댓글 수: 1
Jacob Barrett-Newton
Jacob Barrett-Newton 2018년 2월 11일
well after I identify which rows contain which bit of text, I can then extract the values from the corresponding columns and plot it. The required text is also imported. Its a table with the text i need in the second column. At the moment now that I can find the row I can just one by one search for it, but like I said being able to loop it would make it a lot cleaner and easier.

댓글을 달려면 로그인하십시오.

추가 답변 (0개)

카테고리

Help CenterFile Exchange에서 Data Type Conversion에 대해 자세히 알아보기

태그

Community Treasure Hunt

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

Start Hunting!

Translated by