В данном уроке рассматриваются примеры работы с файлами последовательного и прямого доступа.
Конструируя данное приложение, вы на практике узнаете, как осуществить:
Считывание файла последовательного доступа в поле
Запись в файл последовательного доступа
Считывание и запись в файл прямого доступа
Работу с пользовательскими типами данных
Создание простейшего текстового редактора
Создание заставки приложения
Практика
Файл последовательного доступа
При последовательном доступе файл рассматривается как последовательность строк произвольной длины, разделенных специальными знаками. Чтение из файла и запись в файл производится построчно.
Приведенная ниже программа является примером создания простейшего текстового редактора, в который можно загрузить из файла уже существующий текст, отредактировать его и записать измененный текст в файл. Имя открываемого файла вводится в переменную имяФайла. Свободный номер для файла получается при помощи функции FreeFile и записывается в переменную Номер.
Итак, в редакторе форм создадим диалоговое окно Файл последовательного доступа (рис. У 14.1).
Рис. У14.1. Диалоговое окно Файл последовательного доступа
Обсудим, как приведенная ниже программа решает описанную задачу и что в ней происходит.
UserForm_Initialize
Активизирует диалоговое окно.
Отображает переключатель Подсказка и скрывает поле и кнопку Сохранить изменения?.
Устанавливает свойства поля, кнопки, а также задает заголовок диалогового окна.
ToggleButton1_Click
При установке переключателя отображается поле, в которое выводится текст из файла, а также отображается кнопка Сохранить изменения? При снятии переключателя, поле и кнопка скрываются.
Нажатие кнопки
Сохранить изменения?
запускает на выполнение процедуру
CommandButton1_Click
Записывает содержимое поля в файл.
Открытие
и
Запись
Процедуры считывают содержимое файла в поле и записывают содержимое поля в файл соответственно.
'
' Переменные уровня модуля
'
Option Explicit
Dim ИмяФайла As String
Dim Номер As Integer
'
Private Sub CommandButtonl_Click()
'
' По нажатию кнопки содержимое поля записывается в файл
Запись
End Sub
'
Private Sub ToggleButtonl_Click()
'
' При установке переключателя отображается поле,
' в которое выводится текст из файла, и кнопка для
' записи изменений в поле в файл.
' При снятии переключателя поле и кнопка скрываются
' Открывается файл последовательного доступа для записи информации
Open ИмяФайла For Output As Номер
' Содержание поля выводится в файл
'
Print #Номер, TextBoxl.Text
'
' Закрытие файла
'
Close Номер
'
End Sub
Sub Открытие()
'
' Считывание из файла в поле
' Открывается файл последовательного доступа для считывания информации
Open ИмяФайла For Input As Номер
' Содержание файла выводится в поле
'
TextBoxl.Text = Input(LOF(Номер), Номер)
'
' Закрытие файла '
Close Номер End Sub
Файл произвольного доступа
При последовательном доступе файл рассматривается как последовательность строк фиксированной длины, причем при открытии указывается длина строки. Благодаря этому становится возможным переход на любую запись по ее номеру.
Рис. У14.2. Диалоговое окно для работы с файлом произвольного доступа
Приведенная ниже программа реализует простейшую базу данных с помощью файла произвольного доступа. Данный файл предназначен для хранения информации о студентах: фамилии, имени и группе. Диалоговое окно информация о студентах позволяет перемещаться от записи к записи, редактировать существующие и создавать новые записи. Переход от записи к записи производится при помощи счетчика. Отметим, что заголовок диалогового окна является переменным: при создании нового файла или записи в заголовок выводится информация о студентах, а при выводе информации о текущем студенте — его имя и фамилия. При активизации диалогового окна доступными для пользователя являются только поле со списком и кнопка открытие файла. В поле со списком отображаются все файлы текущей папки с расширением dat. Пользователь может выбрать файл из этого списка или ввести в поле имя нового файла. После ввода имени файла поле со списком и кнопка Открытие файла становятся недоступными для пользователя, а все остальные элементы управления, наоборот, становятся доступными. На стандартном листе модуля описан пользовательский тип студенттуре, который используется в модуле UserForm1 для объявления переменной данного типа. Эта переменная задает структуру в файле произвольного доступа. Имя открываемого или вновь создаваемого файла вводится в переменную ИмяФайла. Свободный номер для файла получается при помощи функции FreeFile и записывается в переменную Номер.
Итак, в редакторе форм создадим диалоговое окно для работы с файлом произвольного доступа (рис. У14.2).
Обсудим, как приведенная ниже программа решает описанную задачу и что в ней происходит.
UserForm Initialize
Активизирует диалоговое окно.
При помощи процедуры Управление задает режим доступа к элементам управления. Пользователю доступны только поле и кнопка Открытие файла .
Задает первоначальный заголовок диалогового окна и надписи с номером текущей записи. 4. Выводит рисунки (стрелки) на поверхность двух кнопок.
Нажатие кнопки Открытие файла запускает на выполнение процедуру
CommandButton4_Click
Открывает или создает файл по имени, которое введено в поле со списком Открытие файла .
Считывает первую запись из файла в диалоговое окно при помощи процедуры Показать Запись .
При помощи процедуры Управление задает режим доступа к элементам управления: пользователю теперь недоступны поле со списком и кнопка Открытие файла, а все остальные элементы управления, наоборот, становятся доступными.
В надписи с номером текущей записи выводится также общее число записей открытого файла.
SpinButton1
Устанавливает границы изменения счетчика. Отметим, что верхняя граница значения счетчика — число записей, может изменяться по ходу программы.
Выводит текущее значение счетчика в пол Номер записи .
Считывает текущую запись из файла в диалоговое окно при помощи процедуры показать Запись .
Нажатие кнопки Новая запись запускает на выполнение процедуру
CommandButtonl_Click
Создает новую запись в конце файла.
Нажатие кнопки Записать изменения запускает на выполнение процедуру
CommandButton2_Click
Считывает из диалогового окна в текущую запись файла информацию при помощи процедуры ЗаписатьЗапись .
Нажатие кнопки Закрыть запускает на выполнение процедуру
CommandButton3 Click
Закрывает открытый файл и диалоговое окно.
Нажатие кнопки запускает на выполнение процедуру
CommandButton5 Click
Осуществляет переход на последнюю запись.
Нажатие кнопки запускает на выполнение процедуру
CommandButton6 Click
Осуществляет переход на первую запись.
Показать Запись
Выводит в поля диалогового окна запись с номером, указанным в переменной текущаяЗапись .
Записать Запись
Записывает в файл из полей диалогового окна запись с номером, указанным в переменной текущаяЗапись .
На листе стандартного модуля наберите описание пользовательского типа:
Option Explicit
Public Type СтудентТуре
Фамилия As String * 30
Имя As String * 30
Группа As String * 11
End Type
На листе модуля userForm1 наберите следующую программу:
Sub Управление(СЗаписями As Boolean, СФайлом As Boolean)
'
Dim ЭлементУправления As Object
For Each ЭлементУправления In Controls
ЭлементУправления.Enabled = СЗаписями Next ЭлементУправления CommandButton4.Enabled = СФайлом
ComboBox1.Enabled = СФайлом
End Sub
В рассмотренном выше приложении последовательно считывалась каждая запись из файла. Если файл с данными небольшой, то иногда удобнее создать массив, компоненты которого являются записями из файла произвольного доступа, а в приложении уже работать не с записями из файла, а с элементами массива. В приведенной ниже программе записи из файла Student.dat, созданного в приложении, считываются в массив студенты с последующим их выводом на рабочий лист.
Open "Student.dat" For Random As #1 Len = ДлинаЗаписи
i = 1
Do Until EOF(l)
Get #1, i, Студенты(i)
' Вывод записи на рабочий лист
Cells (i, 1) .Value = Студенты(i) .Фамилия
Cells (i, 2).Value = Студенты(i).Имя
Cells(i, 3).Value = Студенты(i).Группа
i = i + 1 Loop Close #1
End Sub
Создание заставки приложения
При создании приложений довольно часто принято перед началом его работы создавать заставки с пояснительным текстом: какие функции выполняет приложение, кто является его автором.
Рис. У14.3. Пример заставки приложения
При многократном использовании приложения появление подобной заставки может начать действовать на пользователя, как красная тряпка на быка, поэтому, чтобы не злоупотреблять терпением и временем пользователя в подобных случаях, необходимо предусмотреть режим отказа от вывода заставки при активизации документа. Естественно, программа должна хранить где-то информацию о режиме работы: с заставкой или без нее. Эту и подобную информацию об установках режимов работы приложения обычно хранят в создаваемых дополнительно ini-файлах.
Рассмотрим простейший пример создания заставки приложения (рис. У14.3).
На стандартном листе модуля наберите приведенную ниже процедуру, которая позволит запустить диалоговое окно заставки. В области описания переменных уровня модуля описывается пользовательский тип, используемый при записи информации о режиме работы приложения в файл Файл.INI.
'
' Переменные уровня приложения '
Туре ФАЙЛ_INI
Информация As String * 30 Код As Boolean
End Type '
Public Заставка As ФАЙЛ_INI
'
Sub ПоказатьЗаставку() '
With UserForml
.Picture = LoadPicture("c:my_docbook_exbhv.bmp")
.PictureAlignment = fmPictureAlignmentCenter
.PictureSizeMode = fmPictureSizeModeZoom
.Caption = "Пример заставки"
.BorderColor = vbBlue
.BorderStyle = fmBorderStyleSingle
.CheckBoxl.BackColor = vbWhite .Show
End With
'
End Sub
На листе модуля UserForm1 наберите следующую процедуру, которая при закрытии заставки позволит считать из флажка не отображать выбранный пользователем режим работы для следующего открытия приложения.
Private SubUserFormJIerminate()
Open "Файл.INI" For Random As #1
Len = Len(Заставка)
With Заставка
.Информация = "Отображать заставку:"
If CheckBoxl.Value = False Then .Код = False
End If
If CheckBoxl.Value = True Then .Код = True
End If End With
Put #1, 1, Заставка Close #1
End Sub
На листе модуля ThisWorkbook наберите следующую процедуру, которая при открытии рабочей книги в зависимости от указанного в файле Файл.INI режима либо будет отображать заставку, либо нет.