# How to delete all rows of an array that have a specified number in a particular column?

조회 수: 1 (최근 30일)
L'O.G. 2022년 3월 30일
편집: L'O.G. 2022년 3월 30일
How can you delete a row of an array if the number in a particular column doesn't equal a specified number or even multiple numbers? For example, let A = magic(5). How can we delete any row where A(2,:) = 5? B=A(A(:,2)~=5) doesn't quite do it, only gives me the first column. In this case, there's only one row, but I'm looking for a general solution.

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

### 채택된 답변

Walter Roberson 2022년 3월 30일
A(:, A(2,:) == 5) = [];
##### 댓글 수: 2없음 표시없음 숨기기
L'O.G. 2022년 3월 30일
편집: L'O.G. 2022년 3월 30일
@Walter Roberson Thanks, but that removes the column with that value, not the row. I realized (thanks to you!) that this is what I want: A(A(2,:) == 5,:) = [];
Walter Roberson 2022년 3월 30일
How can we delete any row where A(2,:) = 5
A(2,:) is a query about contents of row 2, not about a particular column. It does not make sense to ask about removing rows for which something is true about row 2.
If you want to deal with columns, then
A = magic(5)
A = 5×5
17 24 1 8 15 23 5 7 14 16 4 6 13 20 22 10 12 19 21 3 11 18 25 2 9
A(A(:,2) == 5, :) = []
A = 4×5
17 24 1 8 15 4 6 13 20 22 10 12 19 21 3 11 18 25 2 9

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

### 카테고리

Help CenterFile Exchange에서 Matrix Indexing에 대해 자세히 알아보기

R2021b

### Community Treasure Hunt

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

Start Hunting!

Translated by