I have a cell array a = {'AA_DFA_DD' ,'DSFA_dfaf' ,'DDDD' , 'DFE1' ,'dfs_DD'}
How can extract only the upper case string from the cell array
my answer should be {'AA_DFA_DD',[],'DDDD','DFE1',[]}
How can i do this?
Thanks a lot

1 commentaire

Stephen23
Stephen23 le 12 Août 2015
+1 for a clear question with input and output examples.

Connectez-vous pour commenter.

 Réponse acceptée

Stephen23
Stephen23 le 12 Août 2015
Modifié(e) : Stephen23 le 12 Août 2015
regexp(a,'^[^a-z]+$','match')

2 commentaires

Gopalakrishnan venkatesan
Gopalakrishnan venkatesan le 12 Août 2015
Modifié(e) : Stephen23 le 12 Août 2015
It works well
Can give me the small explanation of expression
Thanks a lot
Stephen23
Stephen23 le 12 Août 2015
Modifié(e) : Stephen23 le 12 Août 2015
^ % match start of string
[^a-z] % match any character EXCLUDING lower-case
+ % repeated one or more times
$ % match end of string
These are all explained in the documentation:

Connectez-vous pour commenter.

Plus de réponses (1)

Azzi Abdelmalek
Azzi Abdelmalek le 12 Août 2015
Modifié(e) : Azzi Abdelmalek le 12 Août 2015
out=a(cellfun(@(x,y) isequal(x,y),a,upper(a)))
or
out=cell(size(a))
idx=cellfun(@(x,y) isequal(x,y),a,upper(a))
out(idx)=a(idx)

Catégories

Community Treasure Hunt

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

Start Hunting!

Translated by