Табличные типы данных массива в приложениях App Designer

Примечание

Только приложения App Designer и фигуры, созданные с функцией uifigure, поддерживают массивы table. Для получения информации об отображающихся табличных данных в традиционных фигурах смотрите Программное приложение который Отображения Таблица.

Табличные массивы полезны для того, чтобы хранить табличные данные как переменные MATLAB®. Например, можно вызвать функцию readtable, чтобы создать табличный массив из электронной таблицы.

Компоненты Table UI, в отличие от этого, являются компонентами пользовательского интерфейса, которые отображают табличные данные в приложениях. Начиная в R2018a, типы данных, которые можно отобразить в компоненте Table UI, включают табличные массивы.

Когда вы отображаете табличные данные массива в приложениях, можно использовать в своих интересах интерактивные функции для определенных типов данных. И различающиеся другие типы массивов, которые компоненты Table UI поддерживают, табличные данные массива, не отображаются согласно свойству ColumnFormat компонента Table UI.

Логические данные

В компоненте Table UI логические значения отображаются как флажки. значения true проверяются, тогда как значения false неконтролируемы. Когда свойством ColumnEditable компонента Table UI является true, пользователь может выбрать и снять флажки в приложении.

f = uifigure;
tdata = table([true; true; false]);
uit = uitable(f,'Data',tdata);

Категориальные данные

Значения categorical могут появиться как выпадающие списки или как текст. Категории появляются в выпадающих списках, когда свойством ColumnEditable компонента Table UI является true. В противном случае категории отображаются как текст без выпадающего списка.

f = uifigure;
cnames = categorical({'Blue';'Red'},{'Blue','Red'});
w = [400; 700];
tdata = table(cnames,w,'VariableNames',{'Color','Wavelength'});
uit = uitable(f,'Data',tdata,'ColumnEditable',true);

Если массив categorical не защищен, пользователи могут добавить новые категории в запущенном приложении путем ввода в ячейке.

Данные datetime

Значения datetime отображаются согласно свойству Format соответствующей табличной переменной (массив datetime).

f = uifigure;
dates = datetime([2016,01,17; 2017,01,20],'Format','MM/dd/uuuu');
m = [10; 9];
tdata = table(dates,m,'VariableNames',{'Date','Measurement'});
uit = uitable(f,'Data',tdata);

Чтобы изменить формат, используйте запись через точку, чтобы установить свойство Format табличной переменной. Затем замените данные в компоненте Table UI.

tdata.Date.Format = 'dd/MM/uuuu';
uit.Data = tdata;

Когда свойством ColumnEditable компонента Table UI является true, пользователи могут изменить значения даты в приложении. Когда столбец будет доступен для редактирования, приложение ожидает входные значения, которые соответствуют свойству Format массива datetime. Если пользователь вводит недопустимую дату, значением, отображенным в таблице, является NaT.

Данные длительности

Значения duration отображаются согласно свойству Format соответствующей табличной переменной (массив duration).

f = uifigure;
mtime = duration([0;0],[1;1],[20;30]);
dist = [10.51; 10.92];
tdata = table(mtime,dist,'VariableNames',{'Time','Distance'});
uit = uitable(f,'Data',tdata);

Чтобы изменить формат, используйте запись через точку, чтобы установить свойство Format табличной переменной.

tdata.Time.Format = 's';
uit.Data = tdata;

Ячейки, содержащие значения duration, не доступны для редактирования в запущенном приложении, даже когда ColumnEditable компонента Table UI является true.

Нескалярные данные

Нескалярные значения отображают в приложении тот же путь, как они отображаются в Командном окне. Например, этот табличный массив содержит массивы struct и трехмерные массивы.

f = uifigure;
arr = {rand(3,3,3); rand(3,3,3)};
s = {struct; struct};
tdata = table(arr,s,'VariableNames',{'Array','Structure'});
uit = uitable(f,'Data',tdata);

Многостолбцовая табличная переменная типа массив отображается как объединенный столбец в приложении, как это делает в Командном окне. Например, переменная RGB в этом табличном массиве является массивом 3х3.

n = [1;2;3];
rgbs = [128 122 16; 0 66 155; 255 0 0];
tdata = table(n,rgbs,'VariableNames',{'ROI','RGB'})
tdata =

  3×2 table

    ROI           RGB       
    ___    _________________

     1     128    122     16
     2       0     66    155
     3     255      0      0

Компонент Table UI обеспечивает подобное представление. Выбор элемента в столбце RGB выбирает все подстолбцы в той строке. Значения в подстолбцах не доступны для редактирования в запущенном приложении, даже когда свойством ColumnEditable компонента Table UI является true.

f = uifigure;
uit = uitable(f,'Data',tdata);

Пропавшие без вести значений данных

Отсутствующие значения отображаются как индикаторы согласно типу данных:

  • Отсутствующие строки отображаются как <missing>.

  • Неопределенные значения categorical отображаются как <undefined>.

  • Недопустимые или неопределенные числа или значения duration отображаются как NaN.

  • Недопустимые или неопределенные значения datetime отображаются как NaT.

Если свойством ColumnEditable компонента Table UI является true, то пользователь может исправить значения в запущенном приложении.

f = uifigure;
sz = categorical([1; 3; 4; 2],1:3,{'Large','Medium','Small'});
num = [NaN; 10; 12; 15];
tdata = table(sz,num,'VariableNames',{'Size','Number'});
uit = uitable(f,'Data',tdata,'ColumnEditable',true);

Пример: Приложение, который Отображения Табличный Массив

Это приложение показывает, как отобразить компонент Table UI в приложении, которое использует табличные данные массива. Табличный массив содержит numeric, logical, categorical и многостолбцовые переменные.

Обратный вызов StartupFcn загружает электронную таблицу в табличный массив. Затем подмножество отображений данных и построено график в приложении. Оба графика обновляют, когда пользователь редактирует значение в приложении.

Смотрите также

|

Похожие темы

Была ли эта тема полезной?