How to extract only alphabets from mixed string

30 vues (au cours des 30 derniers jours)
Mekala balaji
Mekala balaji le 26 Mar 2016
Modifié(e) : Ced le 26 Mar 2016
Hi,
I have a mixed string as below:
string=BA9K90L
And I only want to extract alphabets i.e., BAKL. Kindly some one help how can we do this.
Many thanks in advance,

Réponse acceptée

Stephen23
Stephen23 le 26 Mar 2016
This is easy using the inbuilt isstrprop function:
>> S = 'BA9K90L';
>> S(isstrprop(S,'alpha'))
ans =
BAKL

Plus de réponses (1)

Ced
Ced le 26 Mar 2016
Modifié(e) : Ced le 26 Mar 2016
Hi
You can use fancy functions like regexp or so, but this is my suggestion:
str = 'BA9K90L';
% pick out letters only (using ASCII value)
str = str(double(str) > 64)
Done! :)
Cheers
EDIT: This does not work if you have more than alphanumeric strings, see Stephen's answer for a complete check.
  5 commentaires
Guillaume
Guillaume le 26 Mar 2016
I totally agree with Stephen. Correct and obvious code trumps fast code. While comparing to 'A' (and that would have been clearer than comparing to 64) works in the toy example provided, it certainly is not robust.
There are tons of characters (>120,000 in the unicode standard) above 64 that may or may not be alphabetic. isstrprop at least attempts to do the right thing and takes into account the current locale.
Ced
Ced le 26 Mar 2016
Modifié(e) : Ced le 26 Mar 2016
@Guillaume:
Of course. I admit that I understood the question as "if I have a string with letters and numbers, how to I extract the letters", as this was given in the example. I have no problem admitting the correctness of his solution, and it was good to point out the limitation. That being said, I see this forum as a place where people share ideas and solutions, and not one of industrial competition. Even Dr. Siva's answer, while being unnecessarily long, is a contribution. It's up to the OP to decide which answer suits their need.
Anyway, that is irrelevant for the topic at hand.

Connectez-vous pour commenter.

Catégories

En savoir plus sur Resizing and Reshaping Matrices dans Help Center et File Exchange

Produits

Community Treasure Hunt

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

Start Hunting!

Translated by