Самоучитель VBA

       

Работа с файлом произвольного доступа


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

Put

Записывает содержимое переменной в файл произвольного доступа.

Синтаксис:



Put [#] НомерФайла, [НомерЗаписи] , ИмяПеременной

  • НомерФайла — номер файла

  • НомерЗаписи — номер записи (режим Random) или номер байта (режим Binary), с которого следует начать запись. Если аргумент НомерЗаписи опущен, то записывается на то место, где был установлен указатель после выполнения последней инструкции Get или Put, либо куда он переведен с помощью функции Seek

    ИмяПеременной — имя переменной, содержащей данные, которые следует записать в файл

  • Get

    Читает данные из открытого файла произвольного доступа в переменную. Синтаксис:

    Get [#] НомерФайла, [НомерЗаписи] , ИмяПеременной

  • НомерФайла — номер файла

  • НомерЗаписи — номер записи (для файлов в режиме Random) или номер байта (для файлов в режиме Binary), с которого следует начать чтение

    Имяпеременной — имя переменной, в которую следует поместить считанные данные

  • Seek

    Функция возвращает значение типа Long, определяющее текущее положение указателя чтения/записи внутри файла, открытого с помощью инструкции Open.

    Синтаксис:

    Seek (НомерФайла)

    LOF

    Функция возвращает значение типа Long, представляющее размер файла в байтах, открытого с помощью инструкции Оpen . Для определения размера закрытого файла следует использовать функции FileLen.

    Синтаксис:

    LOF (НомерФайла)

    FileLen

    Возвращает значение типа Long, содержащее размер файла в байтах.

    Синтаксис:

    FileLen (Путь )

    Как видно из приведенного в предыдущем разделе примера для считывания информации при помощи инструкции input # из файла группаЭкономистов, файл последовательного доступа иногда удобно задавать как последовательность записей (в данном случае, записей о студентах), причем каждая из записей формируется из группы полей (в данном случае из полей Фамилия и оценка).
    Отметим, что такая группировка по записям не является чем-то присущим файлам последовательного доступа. Это просто подход, позволяющий упростить процесс последовательного считывания записей. В файле последовательного доступа существует только одна внутренняя структура, образованная разделителями (запятыми или специальными символами, обозначающими переход на новую строку).

    В противоположность файлам последовательного доступа, в файлах произвольного доступа запись является встроенным элементом. Файл произвольного доступа — это файл, упорядоченный по записям, что позволяет быстро переместиться на любую запись, минуя предыдущие.

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

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

    Отметим, что при открытии файла произвольного доступа, в отличие от файла последовательного доступа, не надо специально указывать, открывается он для ввода или вывода информации. Ввод и вывод информации определяют команды Put и Get.

    Приведем один, пример работы с файлом произвольного доступа группа Экономистов, который имеет ту же структуру, что и в предыдущем примере. Файл создается с помощью процедуры записьвоайл, которая последовательно считывает данные из первого и второго столбца рабочего листа и затем вводит их в файл. В этой процедуре число вводимых записей фиксировано и равно 5. Процедура Считываниеизфайла производит обратное действие — считывает данные из файла и вводит их в ячейки третьего и четвертого столбца рабочего листа. Интересной особенностью файла произвольного доступа является то, что при работе с ним можно определить число записей не пересчитывая их.


    Число записей равно отношению размера файла к длине одной записи. Длина записи устанавливается при создании файла произвольного доступа и определяется типом переменной, при помощи которой файл был создан, размер открытого файла возвращается функцией LOF, а еще не открытого — функцией FileLen. В рассматриваемом случае число записей в файле равно LOF(l) / Len(Студент).

    Туре Студенты

    Фамилия As String * 20 Оценка As String * 3

    End Type

    '

    Sub ЗаписьВФайл()

    Dim Студент As Студенты

    Dim i As Integer

    Open "ГруппаЭкономистов"

    For Random As #1 Len = Len(Студент)

    For i = 1 To 5

    With Студент

    .Фамилия = Cells(i, 1).Value .Оценка = Cells(i, 2).Value

    End With

    Put #1, i, Студент

    Next i

    Close #1

    End Sub '

    Sub СчитываниеИзФайла()

    Dim Студент As Студенты

    Dim i As Integer

    Dim n As Integer

    Open "ГруппаЭкономистов"

    For Random As #1 Len = Len(Студент)

    n = LOF(l) / Len(Студент)

    For i = 1 To n

    Get #1, i, Студент

    With Студент

    Cells (i, 3) .Value = .Фамилия Cells(i, 4).Value = .Оценка

    End With

    Next i

    Close #1

    End Sub




    Содержание раздела