У меня есть скрипт Matlab, который просматривает информацию в файле .xsl и в файле DICOM. Я записал информацию в обоих файлах, которые должны соответствовать. Я создал скрипт, который может просматривать информацию в обоих файлах и в операторе if / else он будет отображать «Perfect Match», «Error 1», «Error 2». После этого я обычно вручную перемещаю файлы в соответствующие папки.
Однако недавно я получил много файлов, которые мне необходимы для выполнения этой проверки. Вместо того, чтобы вручную перемещать файлы, есть ли способ автоматизировать это, надеюсь, связав его с оператором if / else? Вот фрагмент кода: РЕДАКТИРОВАТЬ: мне сказали в комментарии, что моего предоставленного кода недостаточно, поэтому я добавил к нему больше
clear;clc
Mosaiq_missing=[];Mismatch_dose_plan=[];no_plan=[];false_dose=[];
dirpat='C:\Users\X\Desktop\pts\';
[patnamen,~]=getfil(dirpat);
dirloc='C:\Users\X\Desktop\MOSAIQ_values.xlsx';
MOSAIQ=readtable(dirloc);
% MOSAIQ.ida=cellstr(num2str(MOSAIQ.ida));
oma=MOSAIQ(ismember(MOSAIQ.ida, patnamen),:);
co=[2 2 2 2 2 2];dc=1;
for pp=1:length(patnamen)
clearvars -except dirpat patnamen dc pp Mosaiq_missing Mismatch_dose_plan no_plan false_dose wrong_dose_dir repeat oma oma_namen
mismatch=0; hl=0;
patientname=patnamen{pp};
if ismember(patientname,oma.ida)
display(['loading patient: ',patientname])
dirloc=[fullfile(dirpat,patientname),'\'];
pa = genpath(dirloc);
splitfil=regexp(pa,'\;','split')';
% read dose plan locations
DOSEplek=cellfun(@isempty,regexp(splitfil,'DOSE'))==0;
PLANplek=cellfun(@isempty,regexp(splitfil,'PLAN'))==0;
DOSE=splitfil(DOSEplek);
PLAN=splitfil(PLANplek);
if sum(PLANplek)>0
[RTplan_files,~]=getfil(PLAN{1});
for pl=1:length(RTplan_files)
info=dicominfo(fullfile(PLAN{1},RTplan_files{pl}));
beam_name=cell(length(fieldnames( info.FractionGroupSequence.Item_1.ReferencedBeamSequence)),1);
BeamMetersets=nan(length(fieldnames( info.FractionGroupSequence.Item_1.ReferencedBeamSequence)),1);
for p=1:length(fieldnames( info.FractionGroupSequence.Item_1.ReferencedBeamSequence))
BeamMetersets(p)=info.FractionGroupSequence.Item_1.ReferencedBeamSequence.(['Item_',num2str(p)]).BeamMeterset;
beam_name(p)={info.BeamSequence.(['Item_',num2str(p)]).BeamDescription};
end
fraction_number=info.FractionGroupSequence.Item_1.NumberOfFractionsPlanned;
end
%match to MOSAIQ_EXCEL_FILE
% This is where things get separated, So I assume this is where movefile code would go
loc=ismember(oma.ida,patientname);%cellfun(@isempty,regexpi(oma_namen,patientnaam))==0;
MOSAIQ_sel=table2cell(oma(loc,:));
if size(MOSAIQ_sel,1)==size(BeamMetersets,1)
if sum(~ismember(BeamMetersets,cell2mat(MOSAIQ_sel(:,10))))==0
disp('Perfect Match!!!')
else
disp('Error1')
BeamMetersets
mosaiq_beam_values=cell2mat(MOSAIQ_sel(:,10))
end
else
disp('Error 2')
end
end
end
end
Я пытался использовать movefile, но не смог заставить его работать. Я хотел, чтобы файл переместился в папку, например: 'C: \ Users \ X \ Desktop \ PerfectMatch \' 'C: \ Users \ X \ Desktop \ Error1 \' 'C: \ Users \ X \ Desktop \ Error2 \ '