Deleting range of rows in a time series data

조회 수: 6 (최근 30일)
Sewwandhi Chandrasekara
Sewwandhi Chandrasekara 2024년 6월 20일
댓글: Sewwandhi Chandrasekara 2024년 7월 1일
I have time series of rainfall data. The column 1=year, 2=month, 3=date (from 1 to 31), 4=daily rainfall value. I want to remove the rows which have range of data from year 1995 to 2016. I managed to do for one year. But not for range. How can I do so? Many thanks in advance.
RF(find(RF==1([1995:2016],:)=[] I did this code, but says error of using : inbetween 1995 & 2016

채택된 답변

Anurag Ojha
Anurag Ojha 2024년 6월 20일
Hey
To remove the rows with a range of years from 1995 to 2016, you can use logical indexing in MATLAB. Here's an example code snippet that demonstrates how to achieve this:
I have taken a simpler sample data, Kindly modify the code as per your use case:
% Sample data creation
% Columns: year, month, date, daily rainfall value
data = [
1990, 1, 1, 10;
1992, 5, 15, 5;
1995, 7, 21, 12;
2000, 2, 11, 8;
2010, 8, 23, 7;
2016, 12, 31, 20;
2017, 3, 14, 3;
2020, 6, 5, 15;
2022, 10, 19, 4;
];
% Display the original data
disp('Original Data:');
Original Data:
disp(data);
1990 1 1 10 1992 5 15 5 1995 7 21 12 2000 2 11 8 2010 8 23 7 2016 12 31 20 2017 3 14 3 2020 6 5 15 2022 10 19 4
% Create a logical index for rows that fall outside the range 1995-2016
index = (data(:, 1) < 1995 | data(:, 1) > 2016);
% Remove the rows that satisfy the logical index
filtered_data = data(index, :);
% Display the filtered data
disp('Filtered Data:');
Filtered Data:
disp(filtered_data);
1990 1 1 10 1992 5 15 5 2017 3 14 3 2020 6 5 15 2022 10 19 4

추가 답변 (0개)

카테고리

Help CenterFile Exchange에서 Language Fundamentals에 대해 자세히 알아보기

Community Treasure Hunt

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

Start Hunting!

Translated by