Using find for table values

조회 수: 70 (최근 30일)
Fredrik Rapphed
Fredrik Rapphed 2021년 12월 8일
댓글: dpb 2021년 12월 8일
I have a table that is 1764x1, lets call it T. Each value is either 100, 90, 80 or 73. I want to find the indicies of these values in my table. I have tried using find(T==100) to find these values but then i get the error:
"Operator '==' is not supported for operands of type 'table'."
So I try to convert it using table2array(T) but then T turns into a categorical type and when i try to use find with the convertet T i get the error saying "Invalid types for comparison."
How can I find the indicies of specific values in my table?
  댓글 수: 1
Rik
Rik 2021년 12월 8일
I suspect ismember will help. Can you give a small example of your data?
Note that a table contains variables, not values. That means you have to select the correct variable first.

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

채택된 답변

Fredrik Rapphed
Fredrik Rapphed 2021년 12월 8일
편집: Fredrik Rapphed 2021년 12월 8일
I used made the table into a categorical and then converted it to double then i could use the find function as I showed above.
doubleVals = str2double(cellstr(CategoricalVals));
id=find(doubleVals == 100)
  댓글 수: 5
Fredrik Rapphed
Fredrik Rapphed 2021년 12월 8일
Ah right, thank you!
dpb
dpb 2021년 12월 8일
find isn't needed just for indexing and adds the overhead of converting the logical array of the expression in the argument to actual indices along with the overhead to deallocate the logical array and reallocate the double array of indices. It works, yes, but just adds a layer of additional operations that don't add anything for the purpose of only addressing and returning the locations in the subject array that are True in the logical indexing array.
There are instances where one may actually need the indices themselves; it is in those cases for which find should be reserved.
See the "Tips" section in the documenation that expressly mentions the specific use -- I think these should be in the Description section at the top and bolded so folks will actually have to read them to get past the beginning.

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

추가 답변 (1개)

dpb
dpb 2021년 12월 8일
Rik's second comment is the pertinent one here -- you're appying the function to the entire table, not a variable within the table.
ix=find(T.Var1==100);
will address the variable named 'Var1' -- use the correct name for the variable of interest from your own table, of course, in place.
NB: the other comment as well plus another of my own -- it is often not needed to actually use find and convert the logical expression into actual row numbers --
T.Var1(T.Var1==100)
returns the same elements directly from the logical addressing vector.

카테고리

Help CenterFile Exchange에서 Matrices and Arrays에 대해 자세히 알아보기

제품


릴리스

R2020a

Community Treasure Hunt

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

Start Hunting!

Translated by