How to extract rows from a table based on the categories present in one of the columns?

조회 수: 16 (최근 30일)
I have created a table that has double and categorical columns.How can I extract the rows that correspond to each one of the categories?
Being more specific, the table is called 'Plate' and one of the columns 'Invivo'.
If I write
categories(Plate.Invivo);
The answer gives me three categories
'Drug'
'Positive control'
'mock'
If I write
b=Plate(Plate.Invivo=='Drug',:);
The answer is a table with 0 rows and the same number of columns as the original table. Why it can not find the rows that correspond with the categorie 'Drug'?
Thanks a lot for your help

채택된 답변

Esperanza Linares Guerrero
Esperanza Linares Guerrero 2020년 6월 22일
The reason why you are getting an empty array, is because your category is not Drugs, it is 'Drugs' (between quotes). You can remove the quotes from the table and the command would work, or, you can define a variable that contains the quotes:
a=Plate.Invivo(end);%%% Checking your table, the last row has the 'Drugs' category
b=Plate.Invivo(Plate.Invivo==a,:)

추가 답변 (1개)

KSSV
KSSV 2020년 6월 19일
편집: KSSV 2020년 6월 19일
b=Plate(strcmp(Plate.Invivo,'Drug'),:);
  댓글 수: 1
Ildefonso Vicente Suarez
Ildefonso Vicente Suarez 2020년 6월 20일
Thanks a lot for answering my question. When I used your line of code the answer is a table with 0 rows.
I am attaching the table to this comment.

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

카테고리

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

태그

Community Treasure Hunt

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

Start Hunting!

Translated by