Math form and uitable

1 回表示 (過去 30 日間)
john
john 2014 年 1 月 13 日
コメント済み: john 2014 年 1 月 15 日
Hi, I have uitable and edit box. If I write 0.10000002 into edit box, than in uitable I get 0.10000002....this is ok. But if I write 0.00000002, than I get 0.00000002....but how can I get it in form 2.0*10^(-8)???
Thank you.
This is my code:
UserData.celkovamatica=cell(2,2);
for i=1:2
for j=1:2
UserData.celkovamatica{i,j}='0';
end
end
UserData.celkovamatica{1,1}=sscanf(get(handles.edit6,'string'), '%s');
T2=cellstr(char(UserData.celkovamatica{1,1}));
result=strcat('<HTML>',T2);
t = uitable('Parent',f,'Data',result)

採用された回答

Walter Roberson
Walter Roberson 2014 年 1 月 13 日
Your code
sscanf(get(handles.edit6,'string'), '%s')
has the same effect as
get(handles.edit6, 'string')
unless the contents of the edit box have multiple parts separated by spaces (in which case your code pulls out only the first one.)
In order to get 2.0*10^(-8) you would need to convert to numeric form and then convert the numeric form to string using a different format.
If you convert to numeric form and store numbers into UserData.celkovamatica instead of strings, then you could set ColumnFormat to 'short g' to get 2e-08 as the output.
If that is not acceptable, then you will need to store strings (like you do now) and format it yourself, such as
s = sprintf( '%.1e', str2double(get(handles.edit6,'string')));
and then do string manipulation on the '2.0e-08' that results
UserData.celkovamatica{1,1} = regexp(s, {'e', '$'}, {'*10^(', ')'})
  3 件のコメント
Walter Roberson
Walter Roberson 2014 年 1 月 15 日
Make it regexprep() instead of regexp()
john
john 2014 年 1 月 15 日
OK, thank you

サインインしてコメントする。

その他の回答 (0 件)

カテゴリ

Help Center および File ExchangeMigrate GUIDE Apps についてさらに検索

タグ

Community Treasure Hunt

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

Start Hunting!

Translated by