Delete rows in cell that contain part of string

26 vues (au cours des 30 derniers jours)
newbie9
newbie9 le 13 Mar 2019
Commenté : newbie9 le 13 Mar 2019
I have an Nx2 cell (mixes of strings and doubles) that I'm trying to clean up (rawdata). Specifically, I am trying to delete all rows with ">" in the first column. My code below is deleting those rows, but it is reshaping the cell as an Mx1 cell (data1). I'm not sure where the error is. Thanks for any help.
rawdata = textscan(fid, '%s %s' , 'HeaderLines', 7);
rawdata = [rawdata{:}];
data1 = rawdata(cellfun(@(s)isempty(regexp(s,'>')),rawdata));

Réponse acceptée

madhan ravi
madhan ravi le 13 Mar 2019
Modifié(e) : madhan ravi le 13 Mar 2019
Cell(strcmp(Cell(:,1),'>'),:)=[]
  1 commentaire
newbie9
newbie9 le 13 Mar 2019
that works perfectly, thank you

Connectez-vous pour commenter.

Plus de réponses (1)

newbie9
newbie9 le 13 Mar 2019
Modifié(e) : newbie9 le 13 Mar 2019
Below works, but perhaps is not the most elegant code.
rawdata = textscan(fid, '%s %s' , 'HeaderLines', 7);
fclose all;
rawdata = [rawdata{:}];
idx = strfind(rawdata(:,1),'>');
tf = cellfun('isempty', idx);
tf = [tf tf];
data1 = rawdata(tf);
data1 = reshape(data1,[length(data1)/2, 2]);

Catégories

En savoir plus sur Startup and Shutdown dans Help Center et File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by