Filter löschen
Filter löschen

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

21 Ansichten (letzte 30 Tage)
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.

Akzeptierte Antwort

Cris LaPierre
Cris LaPierre am 7 Jul. 2021
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 Kommentare
Jordan
Jordan am 7 Jul. 2021
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 am 7 Jul. 2021
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

Melden Sie sich an, um zu kommentieren.

Weitere Antworten (0)

Kategorien

Mehr zu Characters and Strings finden Sie in Help Center und File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by