Преобразуйте массив ячеек в таблицу
преобразует содержимое T = cell2table(C)m- n массив ячеек, C, к m- n таблица, T. Каждый столбец C обеспечивает данные, содержавшиеся в переменной T.
Создать имена переменных в выходной таблице, cell2table добавляет номера столбцов к имени входного массива. Если входной массив не имеет никакого имени, то cell2table создает имена переменных формы 'Var1'..., 'Var, где N' количество столбцов в NC.
составляет таблицу от массива ячеек, T = cell2table(C,Name,Value)C, с дополнительными опциями, заданными одним или несколькими Name,Value парные аргументы.
Например, можно задать имена строки или имена переменных, чтобы включать в таблицу.
Создайте массив ячеек, содержащий векторы символов и числовые данные.
C = {5 'cereal' 110 'C+'; 12 'pizza' 140 'B';...
23 'salmon' 367 'A'; 2 'cookies' 160 'D'}C=4×4 cell
{[ 5]} {'cereal' } {[110]} {'C+'}
{[12]} {'pizza' } {[140]} {'B' }
{[23]} {'salmon' } {[367]} {'A' }
{[ 2]} {'cookies'} {[160]} {'D' }
Преобразуйте массив ячеек, C, к таблице и задают имена переменных.
T = cell2table(C,... 'VariableNames',{'Age' 'FavoriteFood' 'Calories' 'NutritionGrade'})
T=4×4 table
Age FavoriteFood Calories NutritionGrade
___ ____________ ________ ______________
5 {'cereal' } 110 {'C+'}
12 {'pizza' } 140 {'B' }
23 {'salmon' } 367 {'A' }
2 {'cookies'} 160 {'D' }
Переменные T.Age и T.Calories являются числовыми в то время как переменные T.FavoriteFood и T.NutritionGrade массивы ячеек из символьных векторов.
Преобразуйте массив ячеек в таблицу, и затем включайте первую строку от массива ячеек как имена переменных для таблицы.
Создайте массив ячеек, где первая строка содержит векторы символов, чтобы идентифицировать заголовки столбцов.
Patients = {'Gender' 'Age' 'Height' 'Weight' 'Smoker';...
'M' 38 71 176 true;...
'M' 43 69 163 false;...
'M' 38 64 131 false;...
'F' 38 64 131 false;...
'F' 40 67 133 false;...
'F' 49 64 119 false}Patients=7×5 cell
{'Gender'} {'Age'} {'Height'} {'Weight'} {'Smoker'}
{'M' } {[ 38]} {[ 71]} {[ 176]} {[ 1]}
{'M' } {[ 43]} {[ 69]} {[ 163]} {[ 0]}
{'M' } {[ 38]} {[ 64]} {[ 131]} {[ 0]}
{'F' } {[ 38]} {[ 64]} {[ 131]} {[ 0]}
{'F' } {[ 40]} {[ 67]} {[ 133]} {[ 0]}
{'F' } {[ 49]} {[ 64]} {[ 119]} {[ 0]}
Исключите заголовки столбцов и преобразуйте содержимое массива ячеек к таблице.
C = Patients(2:end,:); T = cell2table(C)
T=6×5 table
C1 C2 C3 C4 C5
_____ __ __ ___ _____
{'M'} 38 71 176 true
{'M'} 43 69 163 false
{'M'} 38 64 131 false
{'F'} 38 64 131 false
{'F'} 40 67 133 false
{'F'} 49 64 119 false
Таблица, T, имеет имена переменных C1,...,C5.
Измените имена переменных путем установки свойства таблицы, T.Properties.VariableNames, к первой строке массива ячеек.
T.Properties.VariableNames = Patients(1,:)
T=6×5 table
Gender Age Height Weight Smoker
______ ___ ______ ______ ______
{'M'} 38 71 176 true
{'M'} 43 69 163 false
{'M'} 38 64 131 false
{'F'} 38 64 131 false
{'F'} 40 67 133 false
{'F'} 49 64 119 false
C — Введите массив ячеекВведите массив ячеек, заданный как 2D массив ячеек. Каждый столбец C обеспечивает данные для табличной переменной.
Если содержимое ячеек в столбце C имейте совместимые размеры и типы, затем соответствующая табличная переменная является вертикальной конкатенацией того содержимого в массив.
Если содержимое ячеек в столбце имеет различные размеры и типы, то соответствующая табличная переменная является массивом ячеек.
Если содержимое ячеек в столбце является всеми векторами символов, то соответствующая табличная переменная является массивом ячеек из символьных векторов.
Задайте дополнительные разделенные запятой пары Name,Value аргументы. Name имя аргумента и Value соответствующее значение. Name должен появиться в кавычках. Вы можете задать несколько аргументов в виде пар имен и значений в любом порядке, например: Name1, Value1, ..., NameN, ValueN.
'RowNames',{'row1','row2','row3'} использует имена строки, row1, row2, и row3 для таблицы, T.'RowNames' — Строка называет для T{} (значение по умолчанию) | массив ячеек из символьных векторов | массив строкСтрока называет для T, заданный как разделенная запятой пара, состоящая из 'RowNames' и массив ячеек из символьных векторов или массив строк, элементы которого непусты и отличны. Количество имен должно равняться количеству строк, size(C,1).
'VariableNames' — Имена переменных для TИмена переменных для T, заданный как разделенная запятой пара, состоящая из 'VariableNames' и массив ячеек из символьных векторов или массив строк, элементы которого непусты и отличны. Количество имен должно равняться количеству переменных, size(C,2).
Имена переменных могут иметь любые символы Unicode®, включая символы non-ASCII и пробелы.
T — Таблица OutputВыведите таблицу, возвращенную как таблица. Таблица может сохранить метаданные, такие как описания, переменные модули, имена переменных и имена строки. Для получения дополнительной информации смотрите раздел Properties table.
Поведение изменяется в R2019b
Таблица и имена переменных расписания с продвижением или запаздывающими пробельными символами не изменяются.
В предыдущих релизах, ведя и запаздывающих пробельных символах были удалены из имен переменных, когда вы задали их использующий 'VariableNames' аргумент пары "имя-значение", или присвоенный их VariableNames свойство.
Чтобы вручную удалить такие символы, сначала используйте strtrim функция на именах, затем присвойте их как имена переменных к таблице или расписанию.
Указания и ограничения по применению:
В сгенерированном коде необходимо задать 'VariableNames' аргумент пары "имя-значение" при использовании этой функции. Для получения дополнительной информации смотрите Генерацию кода для Таблиц (MATLAB Coder) и Табличные Ограничения для Генерации кода (MATLAB Coder).
array2table | isvarname | struct2table | table | table2cell
У вас есть модифицированная версия этого примера. Вы хотите открыть этот пример со своими редактированиями?
1. Если смысл перевода понятен, то лучше оставьте как есть и не придирайтесь к словам, синонимам и тому подобному. О вкусах не спорим.
2. Не дополняйте перевод комментариями “от себя”. В исправлении не должно появляться дополнительных смыслов и комментариев, отсутствующих в оригинале. Такие правки не получится интегрировать в алгоритме автоматического перевода.
3. Сохраняйте структуру оригинального текста - например, не разбивайте одно предложение на два.
4. Не имеет смысла однотипное исправление перевода какого-то термина во всех предложениях. Исправляйте только в одном месте. Когда Вашу правку одобрят, это исправление будет алгоритмически распространено и на другие части документации.
5. По иным вопросам, например если надо исправить заблокированное для перевода слово, обратитесь к редакторам через форму технической поддержки.