How to use if statements to compare data from matlab with excel data?
조회 수: 2 (최근 30일)
이전 댓글 표시
Hey there guys, I'm new here and I'm doing a research for my thesis about eye detection. I've got the exact eye position in a .csv file as shown in this picture:
problem is, there are some of the frames that is not detected and needed to be skipped from the frameNum as you can see in this excel file, there is no frame 9, 10, 11, 12, 13 and many more.
BB = step(EyeDetectKanan,muka); %in this line, the frameNum should be compared with the Frame column in excel.
boxRightEye = BB;
My proposed algorithm for this problem is: 1. If frameNum = Frame, then show the value of right x, right y, right w, right h (without the commas like in this picture)
2. If frameNum isn't in Frame, then skip into the next frameNum 3. This process will be continued until the end of the file.
My questions are, is it possible to use if statements between matlab and excel? and how can I do these algorithms I made?
Thanks. Sorry for the bad view and english...
댓글 수: 3
Weird Rando
2016년 5월 8일
Maybe something like in MATLAB?
for i = 1:10
if i ~= 5
continue
end
disp(i)
end
채택된 답변
Walter Roberson
2016년 5월 8일
for fn = 1 : frameNum
[tf, idx] = ismember(fn, Frame);
if tf
rx = rightx(idx); ry = righty(idx); rw = rightw(idx); rh = righth(idx);
lx = leftx(idx); ly = lefty(idx); lw = leftw(idx); lh = lefth(idx);
...
end
end
댓글 수: 7
Walter Roberson
2016년 5월 9일
for fn = 1 : frameNum
[tf, idx] = ismember(fn, T.Frame);
if tf
thisrow = T(idx,:);
rx = thisrow.rightX; ry = thisrow.rightY; rw = thisrow.rightW; rh = thisrow.rightH;
lx = thisrow.leftX; ly = thisrow.leftY; lw = thisrow.leftW; lh = thisrow.leftH;
...
end
end
추가 답변 (1개)
Walter Roberson
2016년 5월 8일
No, it is not possible to use "if" statements between excel and MATLAB.
You have two choices:
- Read the entire file and discard what you do not need;
- Read one line at a time and make decisions based upon the content.
To read the entire file at one time, xlsread(), readtable() and textscan() are all good routines.
To read one line at a time, textscan() can still be useful, but so can fgetl() together with strsplit()
참고 항목
카테고리
Help Center 및 File Exchange에서 Spreadsheets에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!