How do i remove rows from a column based on the value of a corresponding column?

조회 수: 10 (최근 30일)
I have a large amount of data that i need to process with Matlab but am quite a novice so unfamiliar with all but the basics. I effectively have a large data file containing thousands of entries and i need to know how i can remove a number of specific rows depending on the corresponding value if that makes any sense at all.
Column A is made up of depth values that range from .0000 to 2000.0000m and column B contains salinity values corresponding with each of these depths for a number of stations over a number of years. I want to find if i can remove all values from column B that correspond with values in column A that are less then or equal to 120.0000m.
If(A<=120.0000 then delete B)
I tried to convey this as best as i could in the expression above but don't know where to start with actual equations so any help would be much appreciated.

채택된 답변

Wayne King
Wayne King 2013년 3월 28일
편집: Wayne King 2013년 3월 28일
Assume X is your data matrix,
Xnew = X(X(:,1)>120,:);
So for example:
X = randi(10,10,2);
Xnew = X(X(:,1)>6,:);
I'm assuming that by column A you mean the 1st column of the matrix.

추가 답변 (1개)

Mahdi
Mahdi 2013년 3월 28일
편집: Mahdi 2013년 3월 28일
Remove=find(A<=120.0000);
B(Remove)=[];
If you also want to remove these values from matrix A, then
A(Remove)=[];
  댓글 수: 1
Mahdi
Mahdi 2013년 3월 28일
The above assumes that you only have one column. If it's in the first column, use A(:,1) and B(Remove,1) and so on.

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

카테고리

Help CenterFile Exchange에서 Oceanography and Hydrology에 대해 자세히 알아보기

Community Treasure Hunt

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

Start Hunting!

Translated by