getfield

Поле массива структур

Описание

пример

value = getfield(S,field) возвращает значение в заданном поле структуры S. Для примера, если S.a = 1, затем getfield(S,'a') возвращает 1.

Как альтернатива getfield, используйте запись через точку, value = S.field. Запись через точку обычно более эффективна.

Если S является нескалярным, тогда getfield возвращает значение в первом элементе массива, эквивалентное S(1).field.

пример

value = getfield(S,field1,...,fieldN) возвращает значение, сохраненное во вложенной структуре. Для примера, если S.a.b.c = 1, затем getfield(S,'a','b','c') возвращает 1.

пример

value = getfield(S,idx,field1,...,fieldN) задает элемент массива структур. Для примера, если S(3,4).a = 1, затем getfield(S,{3,4},'a') возвращает 1.

пример

value = getfield(S,idx,field1,idx1,...,fieldN,idxN) задает элементы полей. Для примера, если S.a(2) = 1, затем getfield(S,'a',{2}) возвращает 1. Точно так же, если S(3,4).a(2).b = 1, затем getfield(S,{3,4},'a',{2},'b') возвращает 1.

Примеры

свернуть все

Получите значение поля из структуры, возвращаемой what функция. what возвращает скалярную структуру с полями, содержащими путь к указанной папке и имена различных видов файлов в папке.

S = what('C:\Temp')
S = struct with fields:
        path: 'C:\Temp'
           m: {'testFunc1.m'}
       mlapp: {0×1 cell}
         mlx: {'testFunc2.mlx'}
         mat: {2×1 cell}
         mex: {0×1 cell}
         mdl: {0×1 cell}
         slx: {0×1 cell}
           p: {0×1 cell}
     classes: {0×1 cell}
    packages: {0×1 cell}

Возвращает имена всех Live скриптов, перечисленных в mlx поле. Когда вы используете getfield функция позволяет получить доступ к полю структуры, возвращаемому функцией, без использования временной переменной для хранения этой структуры.

value = getfield(what('C:\Temp'),'mlx')
value = 1×1 cell array
    {'testFunc2.mlx'}

Вы также можете получить доступ к полю с помощью записи через точку.

value = S.mlx
value = 1×1 cell array
    {'testFunc2.mlx'}

Доступ к полю вложенной структуры. Во вложенной структуре структура на любом уровне может иметь поля, которые являются структурами, и другие поля, которые не являются структурами.

Во-первых, создайте вложенную структуру.

S.a.b.c = 1;
S.a.b.d = 'two';
S.a.b.e = struct('f',[3 4],'g','five');
S.h = 50
S = struct with fields:
    a: [1x1 struct]
    h: 50

Пока S является структурой, полями S.a, S.a.b, и S.a.b.e являются также структурами.

S.a
ans = struct with fields:
    b: [1x1 struct]

S.a.b
ans = struct with fields:
    c: 1
    d: 'two'
    e: [1x1 struct]

S.a.b.e
ans = struct with fields:
    f: [3 4]
    g: 'five'

Верните значение S.a.b.d использование getfield функция. При указании разделенного запятыми списка имен вложенных структур необходимо включать структуры на каждом уровне между структурой в верхней части и именем заданного поля. В этом случае список , разделенный запятыми имен структур 'a','b' и имя поля 'd'.

value = getfield(S,'a','b','d')
value = 
'two'

Вы также можете использовать запись через точку для доступа к тому же полю.

value = S.a.b.d
value = 
'two'

Получите значение поля из элемента массива структур, возвращенного dir функция. dir возвращает массив структур, каждый из элементов которого содержит информацию о файле в указанной папке.

Возвращает информацию о файлах в папке C:\Temp. В папке 5 файлов.

S = dir('C:\Temp')
S = 5×1 struct array with fields:
    name
    folder
    date
    bytes
    isdir
    datenum

Чтобы отобразить информацию о пятом файле, индексе в S.

S(5)
ans = struct with fields:
       name: 'testFunc2.mlx'
     folder: 'C:\Temp'
       date: '19-Jul-2018 09:43:53'
      bytes: 2385
      isdir: 0
    datenum: 7.3726e+05

Возвращает имя файла, описанного 5-м элементом S использование getfield функция. Когда вы используете getfield, задайте индексы в массиве ячеек.

value = getfield(S,{5},'name')
value = 
'testFunc2.mlx'

В качестве альтернативы индексируйте в массив структур, а затем используйте запись через точку для задания поля.

value = S(5).name
value = 
'testFunc2.mlx'

Доступ к полю вложенной структуры, в котором структуры на некоторых уровнях являются массивами структур. В этом примере S является массивом структур 1 на 2. Второй элемент, S(2), имеет вложенную структуру a.b, где b является массивом структур 1 на 3.

Во-первых, создайте вложенную структуру. После создания структуры с помощью записи через точку, создайте другой нескалярный массив структуры с помощью struct функционировать и добавить его как поле.

S.a = 1;
S(2).a.b = struct('d',{5,10,20});
S
S=1×2 struct array with fields:
    a

S(2).a.b
ans=1×3 struct array with fields:
    d

Верните значение d от третьего элемента b использование getfield функция. Необходимо задать индексы обоих S и b использование массивов ячеек.

value = getfield(S,{2},'a','b',{3},'d')
value = 20

Вы также можете использовать запись через точку для доступа к тому же полю.

value = S(2).a.b(3).d
value = 20

Создайте структуру с полем, значение которого является массивом.

S.a = [5 10 15 20 25]
S = struct with fields:
    a: [5 10 15 20 25]

Возврат элементов массива с помощью getfield функция. Чтобы вернуть подрешетку, задайте индексы после имени поля. Необходимо задать индексы в массиве ячеек.

value = getfield(S,'a',{[2:4]})
value = 1×3

    10    15    20

Вы также можете использовать запись через точку и индексацию массива для доступа к тем же элементам.

value = S.a(2:4)
value = 1×3

    10    15    20

Входные параметры

свернуть все

Массив структур. Если S является нескалярным, тогда каждый элемент S является структурой, и все элементы имеют одинаковые поля с одинаковыми именами.

Имя поля, заданное как вектор символов или строковый скаляр.

Индексы, заданные как массив ячеек с числовыми или логическими значениями. Индексы для S и поля с 1 по N-1 задают элементы массивов структур. Индексы для поля N задают элементы массива в этом поле, которые могут быть любого типа.

Пример: getfield(S,{1,2},'a') эквивалентно S(1,2).a.

Пример: Если S.a = [5 10 20], затем getfield(S,'a',{[2,3]}) возвращает [10 20].

Представлено до R2006a