Работа с файлами на уровне изменения записей

Работа с файлами на уровне изменения записей происходит по несложному сценарию, который включает в себя операции открытия файла, записи или чтения данных и закрытия файла (рис. 4.22).

 
 

 

 


Рис. 4.22. Сценарий работы с файлом на уровне изменения записи

Работа с файлом независимо от доступа и вида операций начинается с операции открытия файла, т.е. с команды Open. Эта команда сообщает операционной системе имя файла, тип операций, номер буфера[10] файла и для файла прямого доступа длину записи. Завершается работа с файлом командой закрытия файла Close. Эта команда сообщает операционной системе, что буфер свободен и дает сигнал на "выталкивание" в файл остатков информации из буфера. Завершение работы программы с открытыми файлами (без выполнения команды Close) приводит к потере данных, оставшихся в буфере и к нарушению логической структуры диска (появляются потерянные кластеры и пересекающиеся файлы).

В зависимости от способа доступа к записям файла применяют операторы:

· print и write для записи информации в файл последовательного доступа;

· put для записи информации в файл произвольного доступа;

· input для чтения данных любого типа из файла последовательного доступа;

· line input для чтения данных строкового типа из файла последовательного доступа;

· get для чтения данных из файла прямого доступа.

Формат операторов для работы с файлами приведен в табл. 4.12.

Таблица 4-12

Важнейшие команды работы с файлами на уровне записей

Операция Формат команды
Открытие файла прямого доступа: Openфайл[Accessдоступ] [lock] As #буферLen=длина
последовательного доступа: OpenфайлForцель[Accessдоступ] [lock] As #буфер
Закрытие файла всех файлов: Close одного файла: Close #буфер
Запись данных в файл прямого доступа: Put #буфер, номер_записи,переменная последовательного доступа: Print #буфер, список_вывода или Write #буфер,список_вывода
Чтение данных из файла прямого доступа: Get #буфер,номер­_записи,переменная последовательного доступа: Input #буфер, список_ввода или Line Input #буфер, список_ввода
Определение свободного буфера: FreeFile(0)или FreeFile(1) – функция размера файла: Lof (буфер) – функция достижения конца файла при чтении: Eof(буфер)– функция

 


В табл. 4-12 приняты обозначения:

· файл – спецификация или имя файла или имя строковой переменной их содержащей;

· доступ – одно из слов Read (чтение), Write (запись) или Read-Write (чтение-запись) определяющее разрешенные операции с фалом;

· цель – одно из слов Input (ввод из файла), Output (вывод в файл) или Append (добавление в файл);

· lock – одно из ключевых слов Shared (общий), Lock Read, Lock Write, Lock Read-Write (запрещены чтение, запись или чтение-запись соответственно), определяет разрешенные операции с открытым файлом для других программ;

· буфер – номер буфера, выделенного для работы с файлом;

· номер_записи – номер обрабатываемой записи в файле;

· список_ввода – перечень имен данных, разделенных запятыми, указывает адреса записи данных, читаемых из файла;

· список_вывода – перечень имен (значений) данных, разделенных запятыми, указывает адреса и значения данных, выводимых в файл;

· переменная – имя переменной, содержащей данные при выводе и принимающей данные при вводе.

Формат оператора Open достаточно полно описан в указанной таблице. Дополнительно можно отметить, что в режиме output файл создается всегда, а в режиме append – только при отсутствии открываемого файла.

Применение списка вывода в операторе print# и write# позволяет создавать многокомпонентные записи, объединяющие несколько разнородных данных. Оператор write символьные данные заключает в двойные кавычки, которые при вводе оператором input# исключаются.

Предупреждения!!!

1. При создании многокомпонентных записей следует избегать включения в такие записи строковых данных. В крайнем случае, следует включать не более одного компонента типа string и только последним в записи.
В противном случае при исполнении программы возникнет ошибка "Ввод после конца файла", т.к. оператор input# вместе с указанным компонентом прочитает и все последующие как одну строку.

2. В некоторых версиях Visual Basic вывод данных типа single и double в файл оператором print# приводит к потере десятичных точек и дробных частей чисел. Применение оператора write# такого "побочного" эффекта не дает.

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

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