nextblock

Информация о следующем блоке в заблокированном наборе файлов

Синтаксис

Описание

пример

blkInfo = nextblock(bs) возвращает информацию о следующем блоке в BlockedFileSet bs объектазатем переводит внутренний указатель заблокированного набора файлов в следующий блок. Последующие вызовы nextblock функция продолжает считывать из конечной точки предыдущего вызова.

Примеры

свернуть все

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

Создайте заблокированный набор файлов bs для набора файлов.

folder = {'accidents.mat','airlineResults.mat','census.mat','earth.mat'}
folder = 1x4 cell
  Columns 1 through 3

    {'accidents.mat'}    {'airlineResults...'}    {'census.mat'}

  Column 4

    {'earth.mat'}

bs = matlab.io.datastore.BlockedFileSet(folder)
bs = 
  BlockedFileSet with properties:

                   NumBlocks: 4
               NumBlocksRead: 0
                   BlockSize: 'file'
                   BlockInfo: Show BlockInfo for all 4 blocks
    AlternateFileSystemRoots: {}

Используйте hasNextBlock и nextblock функции для чтения информации о блоках по одному блоку за раз, в то время как блоки остаются в наборе.

while hasNextBlock(bs)
   file = nextblock(bs)
end
file = 
  1x1 BlockInfo
                                       Filename                                        FileSize    Offset    BlockSize
    _______________________________________________________________________________    ________    ______    _________

    "/mathworks/devel/bat/BR2021ad/build/matlab/toolbox/matlab/demos/accidents.mat"      7343        0         7343   

file = 
  1x1 BlockInfo
                                          Filename                                           FileSize     Offset    BlockSize 
    ____________________________________________________________________________________    __________    ______    __________

    "/mathworks/devel/bat/BR2021ad/build/matlab/toolbox/matlab/demos/airlineResults.mat"    1.5042e+05      0       1.5042e+05

file = 
  1x1 BlockInfo
                                      Filename                                      FileSize    Offset    BlockSize
    ____________________________________________________________________________    ________    ______    _________

    "/mathworks/devel/bat/BR2021ad/build/matlab/toolbox/matlab/demos/census.mat"      353         0          353   

file = 
  1x1 BlockInfo
                                     Filename                                      FileSize    Offset    BlockSize
    ___________________________________________________________________________    ________    ______    _________

    "/mathworks/devel/bat/BR2021ad/build/matlab/toolbox/matlab/demos/earth.mat"     32522        0         32522  

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

свернуть все

Заблокированный набор файлов, заданный как matlab.io.datastore.BlockedFileSet объект. Как создать BlockedFileSet объект, см. matlab.io.datastore.BlockedFileSet.

Пример: nextblock(bs)

Выходные аргументы

свернуть все

Это свойство доступно только для чтения.

Информация о блоках в BlockedFileSet объект, возвращенный как BlockInfo объект со следующими свойствами:

  • Filename - Имя файла в BlockedFileSet объект. Имя содержит полный путь к файлу.

  • FileSize - Размер файла в байтах.

  • Offset - Начало смещения в файле, который будет считываться.

  • BlockSize - Размер блока в количестве байт.

Совет

  • The nextblock функция возвращает ошибку, если в BlockedFileSet больше не существует блоков объект. Чтобы избежать этой ошибки, используйте nextblock наряду с hasNextBlock и reset. The hasNextBlock функция проверяет, остаются ли блоки в заблокированном наборе файлов, в то время как reset метод сбрасывает внутренний указатель в начало заблокированного набора файлов.

Введенный в R2020a