How to limit input formats in an edit text box?

2 visualizzazioni (ultimi 30 giorni)
In my GUI (programmatic one) there is an edittext box, used to enter coeeficients.
I need to check the format of input and allow only to these types:
5
0.5
1.6
5.9
0.4565132
5.0000
00000.5
Then I'll save them and call back.

Risposta accettata

Tom
Tom il 26 Giu 2013
STR2DOUBLE catches most of those things and outputs NaN if the number isn't valid. The only thing is that it will handle commas. I used REGEXPREP to switch any commas with asterisks so str2double can't process it.
validStr = {'5'
'0,5'
'1.0.6'
'5.9'
'0.4565132'
'5.0000'
'00000.5'};
validStr = regexprep(validStr,',','****');
str2double(validStr)

Più risposte (2)

Tom
Tom il 26 Giu 2013
validStr = {'5'
'0.5'
'1.6'
'5.9'
'0.4565132'
'5.0000'
'00000.5'};
if any(strcmp(get(hEditBox,'String'),validStr))
%code
else
warndlg('Edit box string is not valid.')
end
  1 Commento
Ozan Oguz
Ozan Oguz il 26 Giu 2013
Ok. I guess I cant explain it correctly.
It is like this:
There is a box to enter a coefficient (this can be any real number, and only one of it)
We can't use letters, comma or any other character (except numbers and a single dot, as in 0.04415 or 30.8)
Coefficient can be any real number in the correct format: Just numbers and only a single dot for decimals, if needed.
Thx.

Accedi per commentare.


Sean de Wolski
Sean de Wolski il 26 Giu 2013
Why not just use a popupmenu?
uicontrol('style','popupmenu','string',{'0.5','3.14','1.6'})
  1 Commento
Ozan Oguz
Ozan Oguz il 26 Giu 2013
Ok. I guess I cant explain it correctly.
It is like this:
There is a box to enter a coefficient (this can be any real number, and only one of it)
We can't use letters, comma or any other character (except numbers and a single dot, as in 0.04415 or 30.8)
Coefficient can be any real number in the correct format: Just numbers and only a single dot for decimals, if needed.
Thx.

Accedi per commentare.

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