How do you align numbers within a column in UItable?

We're using GUIDE to build financial applications for investment bankers. They expect to see a column of dollar figures right aligned but there seems to be no obvious way to right align characters in a column in UItable. Any help would be GREATLY appreciated!!!

 Respuesta aceptada

Walter Roberson
Walter Roberson el 10 de Mzo. de 2011
Golf'ing Oleg's solution:
dat = {'23234.43 $'; '234.43 $'; '0.23 $'};
dat = cellfun(@(s) sprintf('%*s',max(cellfun(@length,dat)),s),dat);
and then pick up at "Create table".

3 comentarios

Oleg Komarov
Oleg Komarov el 10 de Mzo. de 2011
The second I submitted the version with the strcat I thought sprintf would be more suited in this case...doh.
BTW, you're missing a 'un',0 in the last cellfun.
Walter Roberson
Walter Roberson el 10 de Mzo. de 2011
Ah yes, you are right, the outer cellfun should have 'un',0
Zoe Zhang
Zoe Zhang el 13 de Ag. de 2012
so smart!

Iniciar sesión para comentar.

Más respuestas (2)

Oleg Komarov
Oleg Komarov el 10 de Mzo. de 2011
I came up with this solution:
dat = {'23234.43 $'; '234.43 $'; '0.23 $'};
Pad string amounts with blanks
l = cellfun(@length,dat);
dat = num2cell([arrayfun(@blanks,max(l)-l,'un',0) dat],1);
dat = strcat(dat{:});
Create table with courier font
f = figure('Position',[200 200 400 150]);
cnames = 'Amounts';
rnames = {'First','Second','Third'};
t = uitable('Parent',f,'Data',dat,'ColumnName',cnames,...
'RowName',rnames,'Position',[20 20 360 100],...
'fontname','courier');
Oleg

2 comentarios

Peter
Peter el 10 de Mzo. de 2011
Unfortunately because it's not a fixed width font the blank padding still doesn't get you to right alignment. Each number takes up a different amount of space - unless I'm missing something.
Oleg Komarov
Oleg Komarov el 10 de Mzo. de 2011
You had to change fontname to a monospaced set

Iniciar sesión para comentar.

Walter Roberson
Walter Roberson el 10 de Mzo. de 2011

0 votos

Does setting the ColumnFormat to 'bank' work ?

2 comentarios

Oleg Komarov
Oleg Komarov el 10 de Mzo. de 2011
It will work with numeric datatypes...not with strings.
Peter
Peter el 10 de Mzo. de 2011
We'd like to have commas and no 0s (dealing with large numbers in the hundreds of millions). 'Bank' format goes out to the penny and has no commas

Iniciar sesión para comentar.

Preguntada:

el 10 de Mzo. de 2011

Community Treasure Hunt

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

Start Hunting!

Translated by