Методические указания и задания к лабораторным работам для учащихся ссуз специальности Т1002 «Программное обеспечение информационных технологий»

Вид материалаМетодические указания

Содержание


Порядок выполнения работы
Контрольные вопросы
Лабораторная работа № 29 Разработка программы для работы с типизированным файлом
Краткие теоретические сведения
Type FileRec = record
Средства работы с типизированными файлами
Longint FileSize(var F) : Longint
Seek(F, FiieSize(F))
Пример программы работы с типизированным файлом
Vid оператор выбора case
Phone переменной типа запись Work
Maska типа StFio
Подобный материал:
1   ...   24   25   26   27   28   29   30   31   32

Порядок выполнения работы

  1. Изучить теоретические сведения по теме “Написание программы на языке Паскаль с использованием файловых переменных. Разработка программы для работы с текстовым файлом”.
  2. Получить у преподавателя индивидуальное задание и разработать программу для работы с текстовым файлом согласно заданному варианту.
  3. Показать работающую программу преподавателю.
  4. Ответить на контрольные вопросы.

Контрольные вопросы

  1. Понятие файла. Описание файлового типа данных.
  2. Файлы последовательного и прямого доступа. Средства обработки файлов.
  3. Текстовые файлы. Процедуры и функции работы с текстовыми файлами.



Лабораторная работа № 29

Разработка программы для работы с типизированным файлом


Цель работы: формирование знаний и умений по работе с типизированными файлами.

Краткие теоретические сведения

Типизированные файлы


К типизированным файлам относятся файлы строго определенного типа. Чаще всего это файлы, состоящие из записей. Они применяются для создания различных баз данных. Стандартное задание в программе такой файловой переменной осуществляется следующим образом:

Type

FileRec = record



end;

Var

F : file of FileRec;

Если в текстовых файлах содержимое рассматривается как наборы символов, подготовленные специальным образом с учетом общепринятых соглашений о представлении текстовой информации, то в типизированных файлах их содержимое рассматривается как последовательность записей определенной структуры. Единицей измерения такого набора данных является сама запись. Длина записи определяется как SizeOf(FileRec). Так как длина любого компонента типизированного файла строго постоянна, это дает возможность организовать прямой доступ к любому компоненту по его порядковому номеру, поэтому типизированные файлы часто называют файлами прямого доступа.

Seek(var F; NumRec: Longint)

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

Средства работы с типизированными файлами


Для работы с файлами прямого доступа дополнительно можно использовать следующие средства:

Truncate(var F);

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

FilePos(var F) : Longint

Функция возвращает для файла F текущую файловую позицию (номер записи, на которую она установлена) в виде значения типа Longint

FileSize(var F) : Longint

и его размер (количество записей) в виде значения типа Longint.

Для пустого файла вызов FileSize возвращает значение 0. Локализация ошибок при обращении к внешним носителям для обоих функций производится через IOresult.

Для того чтобы очередная запись могла быть записана в конец типизированного файла, необходимо перевести текущую файловую позицию в конец файла. Когда создается новый файл, это происходит автоматически после формирования каждой очередной записи. Если файл уже создан и файловая позиция, установленная по Seek, находится где-нибудь в начале файла (FilePos(F) < FileSize(F)), то в конец файла ее позволяет перевести вызов

Seek(F, FiieSize(F));

В каждом файле число логических и физических записей совпадает, а при позиционировании номер физической записи на единицу меньше номера логической записи.

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

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

На практике это выражается в создании так называемых индексных файлов по отношению к главному файлу данных. Индексные файлы содержат номера записей главного файла, отсортированных по конкретному ключу. Такое построение позволяет экономить время обращения к внешним носителям, так как во всех перемещениях при сортировке участвуют записи малой длины, содержащие номера записей главного файла в соответствии с ключом сортировки.

Пример программы работы с типизированным файлом


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

Program BookPhone; {Телефонный справочник}

Uses Crt;

Type

StFio=string[20];

StPhone=string[10];

RecBook=record {Запись сведений об абоненте}

FIO:StFio;

Phone:StPhone;

End;

Var

BookFile:file of RecBook; {Переменная для файла с записями RecBook}

Work:RecBook; {Переменная для доступа к записям}


Vid:byte;

End_Menu:boolean;

Name:String[12];

Procedure Name_File; {Ввод имени файла данных}

Begin

Write(‘Введите имя файла данных телефонного справочника’);

Readln(Name);

End;

Procedure AddRec; {Добавление записи в файл}

Begin

Writeln(‘Ввод записи № ’, FilePos(BookFile)+1); {+ 1 - указывает номер физической записи (к номеру логической записи добавляется 1) }

With Work do

Begin

Writeln(‘Введите фамилию ’);

Readln(FIO);

Write(‘Введите номер телефона ’);

Readln(Phone);

Write(BookFile,Work); {Записать в файл значение переменной Work: фамилию и номер телефона}

End;

End;

Procedure Create_Book_Phone; {Создание нового файла данных}

Var

Ind,Count:integer;

Begin

Name_File;

Assign(BookFile, Name); {Открыть новый файл для записи}

Rewrite(BookFile);

Writeln(‘Создание записей файла ’, Name);

Write(‘Введите число записей в справочнике’);

Readln(Count);

For Ind:=1 to Count do

AddRec;

Writeln(‘Создание фала завершено’);

Writeln(‘Файл данных имеет , FileSize(BookFile), записи’);

Close(BookFile);

End;

Procedure OutputRec; {Вывод текущей записи на экран}

Begin

Read(BookFile,Work);

With Work do

Begin

Write(‘Запись № ’,FilePos(BookFile),’:’);

Writeln(‘ФИО: ’, Fio, ‘телефон: ’,Phone);

End;

End;


Procedure OutputAllRec; {Вывод всех записей файла на экран}

Begin

Name_File;

Assign(BookFile,Name);

{$I-}

Reset(BookFile);

{$I+}

if IOResult=0 then

begin

Seek(BookFile,0); {Установка на первую запись}

Writeln(‘Вывод телефонного справочника из файла’, Name);

While (not EOF(BookFile)) do

OutPutRec;

End

Else

Writeln(‘Файла с именем ’ +Name+’ на диске нет’);

End;

Procedure UpdateRec;

Var

NumRec: LongInt;

Begin

Name_File;

Assign(BookFile,Name); {Открыть новый файл для записи}

{$I-}

Reset(BookFile);

{$I+}

if IOResult=0 then

begin

Write(‘Укажите номер изменяемой записи’);

Readln(NumRec);

Seek(BookFile,NumRec-1); {Установка файловой позиции по указанному номеру записи}

Writeln(‘–Старое значение записи:’);

OutputRec; {Вывод записи и переход на следующую}

Seek(BookFile,NumRec-1); {Возврат на прежнюю позицию}

Writeln(‘Задаем новое значение ’, NumRec, ‘записи’);

AddRec;

Close(BookFile);

End

Else

Writeln(‘Файла с именем ’+Name+’ на диске нет’);

End;

Procedure AddRecToEnd; {добавление записи в конец файла}

Begin

Name_File;

Assign(BookFile,Name);

{$I-}

Reset(BookFile);

{$I+}

if IOResult=0 then

begin

Seek(BookFile,FileSize(BookFile)); {Установка текущей позиции в конец файла}

AddRec;

Writeln(‘Измененный файл данных имеет’, FileSize(BookFile),’записи’);

Close (BookFile);

End

Else

Writeln(‘Файла с именем ’+Name+’ на диске нет);

End;

Procedure FindFio; {Поиск номера телефона по фамилии абонента}

Var

BookFile:file of RecBook;

Work:RecBook;

Maska:StFio;

Rez_Find:boolean;

CountRec:integer;

Begin

Name_File;

Assign(BookFile,Name);

{$I-}

Reset(BookFile);

{$I+}

if IOResult=0 then

begin

Write(‘Введите фамилию для поиска’);

Readln(Maska);

RezFind:=False;

CountRec:=0;

While(not Eof(BookFile)) do {Просмотреть все записи до конца файла}

Begin

Read(BookFile,Work);

With Work do

If Pos(Maska,Fio)<>0 then{Найдена запись абонента с указанной фамилией}

Begin

Rez_Find:=True;

Inc(CountRec);

Writeln(‘Фамилия ’, Fio,’телефон ’,Phone);

End;

End;

If Rez_Find then

Writeln(‘Число записей для ’, Maska,’=’,CountRec)

Else

Writeln(‘В справочнике нет абонентов с фамилией ’, Maska);

Close(BookFile);

End

Else

Writeln(‘Файла с именем ’+Name+’ на диске нет’);

End;


{Основная программа}

Begin

ClrScr;

End_Menu:=False;

Repeat {Повторять показ меню, пока End_Menu=False}

Writeln(‘Телефонный справочник ’);

Writeln(‘Выберите вид работы ’);

Writeln(‘1-создание нового файла ’);

Writeln(‘2-просмотр списка справочника ’);

Writeln(‘3-изменение записи’);

Writeln(‘4-дополнение справочника’);

Writeln(‘5-поиск абонента ’);

Writeln(‘0-завершение работы ’);

Write(‘Ваш выбор ’);

Readln(Vid);

Case Vid of {Вызов разных процедур в зависимости от вида работы}

1: Create_Book_Phone;

2:OutPutAllRec;

3:UpdateRec;

4:AddRecToEnd;

5:FindFio;

0:End_Menu:=True;

end;

Writeln(‘Нажмите клавишу Enter’);

Readln;

ClrScr;

Until End_Menu; {Больше не выводить меню)

End.

В начале программы очищается экран, переменной End_Menu присваивается значение False, и затем на него с помощью оператора повтора repeat выводится текст меню из шести пунктов. В заключение списка вариантов меню выводится запрос и считывается значение переменной Vid, задаваемое пользователем в соответствии с избранным видом работы со справочником.

В зависимости от значения селектора Vid оператор выбора case осуществляет выбор, т. е. выбирают соответствующую значению константы выбора процедуру (например, если Vid=2, то вызывается процедура OutputAllRec для вывода всего содержимого справочника). После выполнения процедуры управление программой передается в конец оператора case, и, так как значение переменной End_Menu не равно True, оператор повтора repeat выполняется вновь, очищая экран и выводя список меню, и так до тех пор, пока пользователь выберет завершение работы. В результате этого переменной Vid будет присвоено значение 0, из-за чего в операторе case переменной End_Menu будет присвоено значение True, и цикл repeat завершится.

В начале процедуры создания нового файла данных справочника записан вызов процедуры задания имени файла данных Name_File. Процедура Name_File записана выше по тексту программы. Создание нового файла данных производится с использованием стандартной процедуры Rewrite. Ввод записей об абонентах описывается с использованием оператора повтора for, параметр Ind которого, изменяясь от 1 до числа записей Count, будет указывать порядковый номер записи с данными абонента в файле. Добавление одной записи в файл данных сделанов виде процедуры AddRec, которая также записана выше в тексте программы.

В окончании процедуры организуется вывод сообщения о результатах создания файла. Для измерения размера файла в записях используется функция FileSize.

Для сокращения записи при обращении к полям Fio и Phone переменной типа запись Work используется предложение with Work do.

Для вывода на экран всех записей файла сначала, используется функция IOresult, выполняется проверку, есть ли данный файл на диске. Если функция IOresult возвращает значение, отличное от 0, то на экран выводится сообщение о том, что данного файла на диске нет, иначе позиционируется указатель на первую запись Seek(BookFile, 0), а затем, используя оператор повтора while, записывается вызов процедуры вывода на экран одной записи OutputRec. Условием окончания цикла while будет выражение Eof(BookFile). Как только оно выполнится, цикл завершится. Данные всех записей файла выведены на экран.

В процедуре поиска номера телефона описаны локальные переменные: Maska типа StFio, которая будет принимать значение фамилии искомого абонента; Rez_Find типа boolean, которая будет принимать значения True или False в зависимости от результатов поиска; CountRec типа integer, значение которой будет равно числу записей с такой фамилией.

После записи запроса имени файла данных справочника и проверки есть ли он на диске, в случае если файл есть, записывается запрос о фамилии искомого абонента. Перед поиском присвоено значения Rez_Find:=False и CountRec:=0. Просмотр всех записей файла данных при поиске записан, используя оператор повтора while. Условие завершения поиска- Eof(BookFile) - достижение конца файла. Если значение поля Fio очередной записи совпадает со значением переменной Maska, то переменной Rez_Find присваивается значение True (абонент найден), значение переменной CountRec увеличивается на 1 и печатается сообщение о фамилии и номере телефона найденного абонента.