Comparing strings with wildcards

234 visualizzazioni (ultimi 30 giorni)
James
James il 26 Mag 2013
Commentato: Flurin Arner il 25 Apr 2018
Hi,
I have a number of strings that I'd like to check for a certain ending however the middle of the strings are all different (the middle of the strings are dates). They are of the format: wrfout****_PLEV or wrfout**** where ** is the date (all dates are of the same length). I basically want to find the strings that do not have _PLEV at the end.
I've tried using strcmp with wildcards but for some reason the creators decided it was a fantastic idea to ignore wildcards altogether which in my opinion negates a lot of potential uses of the strcmp function.
I've also tried using strncmp but that only allows you to specify the first n letters of a string to compare and not the last.
I then tried using simple inequalities, to obtain exactly which characters are the same, such as: 'wrfout****_PLEV == wrfout**** but as expected the different lengths of the strings prevented me from using this idea.
Any ideas as to how to do this or how to compare strings with wildcards would be very useful?
Thanks in advance James

Risposta accettata

Joao Henriques
Joao Henriques il 15 Mag 2014
There's a very simple way, just use regexptranslate:
regexp('abc123x', regexptranslate('abc*x'))
Will return 1 (beggining of matched string). If there's no match, regexp returns empty.
  2 Commenti
Nick Powell
Nick Powell il 23 Ott 2014
Brilliant! Thanks
Flurin Arner
Flurin Arner il 25 Apr 2018
I wanted to add, that regexptranslate will throw an error 'MATLAB:minrhs Not enough input arguments.' like this.
You have to add 'wildcard', to regexptranslate() for it to work:
regexp('abc123x', regexptranslate('wildcard', 'abc*x'))

Accedi per commentare.

Più risposte (1)

the cyclist
the cyclist il 26 Mag 2013
Use the regexp() function.

Categorie

Scopri di più su Characters and Strings in Help Center e File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by