Remove rows from a string array that correspond to rows being thresholded in a separate numeric matrix

13 次查看(过去 30 天)
I have a string array and a separate numeric matrix. The string array is one column with many rows and the numeric matrix is two columns with many rows (the same number of rows as the string array). I want to threshold some of the rows of the numeric matrix, but if a row is removed from the numeric matrix I want the corresponding row number to be removed from the string array. For example, remove any rows where the value is < 0.05 in both columns of the numeric matrix. If rows 2,3,4 meet this condition in the numeric array then remove those rows from the string array as well. Thank you.

采纳的回答

Cris LaPierre
Cris LaPierre 2021-7-7
Use an index to capture the rows that meet your criteria, and then use that index to delete the corresponding rows from both arrays.
txt = ["A";"B";"C"];
num = [1 2; 3 4; 5 6];
% find rows that meet criteria
ind = num(:,2)==4;
% remove rows from string array and matrix
txt(ind) = []
txt = 2×1 string array
"A" "C"
num(ind,:) = []
num = 2×2
1 2 5 6
  2 个评论
Jordan
Jordan 2021-7-7
What if I need the criteria to be met across multiple columns? How would I index the rows that meet that criteria? For example, index rows whose elements are equal to 4 in column 1 and 2?
Cris LaPierre
Cris LaPierre 2021-7-7
Just add additional criteria to your expression. In this case, none of the rows meet both criteria, so nothing is removed.
txt = ["A";"B";"C"];
num = [1 2; 3 4; 5 6];
% find rows that meet criteria
ind = num(:,2)==4 & num(:,1)==4;
% remove rows from string array and matrix
txt(ind) = []
txt = 3×1 string array
"A" "B" "C"
num(ind,:) = []
num = 3×2
1 2 3 4 5 6

请先登录,再进行评论。

更多回答(0 个)

类别

Help CenterFile Exchange 中查找有关 Characters and Strings 的更多信息

Community Treasure Hunt

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

Start Hunting!

Translated by