67460

Стандартные процедуры и функции для работы с любыми файлами

Лекция

Информатика, кибернетика и программирование

Функция возвращает значение 0, если операция открытия файла прошла успешно, и значение, отличное от 0, если открытие не заладилось (например, была попытка открыть на чтение файл, которого нет на диске, или была попытка открыть на запись файл с неприемлемым именем).

Русский

2014-09-10

146 KB

0 чел.

Лекция 8

Стандартные процедуры и функции для работы с любыми файлами

procedure Erase(var F: <Файловый тип>);

procedure Rename(var F: <Файловый тип>;  <Новое имя файла>: string);

procedure MKDir(<Имя папки>: string);        // Создает пустую папку

procedure RMDir(<Имя папки>: string);        // Удаляет пустую папку

function  IOResult: integer;

Функция возвращает значение 0, если операция открытия файла прошла успешно, и значение, отличное от 0, если открытие не заладилось (например, была попытка открыть на чтение файл, которого нет на диске, или была попытка открыть на запись файл с неприемлемым именем).

function EOF(var F: <Файловый тип>) boolean;

Функция возвращает значение true, если маркер файла переместился за последний байт файла (достигнут конец файла).


Замечание

Существуют альтернативные варианты процедур:

procedure Rename(var F <Файловый тип>; <Новое имя файла>: PChar);

procedure MKDir(<Имя папки>: PChar);

procedure RMDir(<Имя папки>: PChar);

PChar – специальный «строковый» тип, разговор о нём пойдёт позже.

Замечание

Файловых типов в языке Паскаль может быть три: текстовые файлы, типизированные файлы и файлы без типа.

Текстовый файл

Тип «Текстовый файл», или файл последовательного доступа, предназначен для работы с т.н. текстовыми файлами (на дисках и не только). Признаком текстового файла является множество байтовых пар с кодами 13 и 10. В литературе для них встречается обозначение CR (Carriage Return, возврат каретки) и LF (Line Feed, перевод строки). Между парами с кодами 13 и 10 обычно стоят символы разговорных алфавитов, образующие осмысленный текст. Для служебных целей текстовые файлы могут содержать, например, числа, представляющие входной набор данных для программы.

<Объявление текстовой файловой переменной> ::=

<Имя файловой переменной>: text;


Стандартные процедуры для работы с текстовыми файлами

Синтаксис TP7:

procedure Assign(var F: <Файловый тип>;  <Имя файла>: string);

Процедура связывает файловую переменную с реальным файлом.

procedure Reset(var F: <Файловый тип>);

Процедура открывает файл для чтения (данных из файла).

procedure Rewrite(var F: <Файловый тип>);

Процедура открывает файл для записи (данных в файл).

procedure Append(var F: <Файловый тип>);

Процедура открывает файл для ДОзаписи данных в конец файла.

procedure Close(var F: <Файловый тип>);

Процедура закрывает ранее открытый файл.

function Assign(var F: <Файловый тип>;  <Имя файла>: string);

Процедура связывает файловую переменную с реальным файлом.

function EOLN(var F: <Файловый тип>) boolean;

Функция возвращает значение true, если маркер файла переместился за последний байт строки (достигнут конец строки).

function SeekEOLN(var F: <Файловый тип>) boolean;

Функция возвращает значение true, если маркер файла переместился за последний байт строки (достигнут конец строки), или если конец строки не достигнут, но до конца строки присутствуют только пробелы и знаки табуляции.

function SeekEOF(var F: <Файловый тип>) boolean;

Функция возвращает значение true, если маркер файла переместился за последний байт файла (достигнут конец файла), или если конец файла не достигнут, но до конца файла присутствуют только пробелы и знаки табуляции.

procedure Flush(var F <Файловый тип>);

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

procedure Read(var F <Файловый тип>; <Список ввода>);

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

procedure Readln(var F < Файловый тип>; <Список ввода>);

Производится чтение данных из текстового файла в переменные, представленные в <Списке ввода> аналогично тому, как это делается процедурой Read. Когда список ввода исчерпан, производится перевод маркера на начало следующей строки текстового файла, даже если до конца текущей строки остаются данные, которые не прочтены.

procedure Write(var F <Файловый тип>; <Список вывода>);

Производится запись данных из <Списка вывода> в текстовый файл.

procedure Writeln(var F <Файловый тип>; <Список вывода>);

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


Синтаксис
Delphi:

<Объявление текстовой файловой переменной> ::=

<Имя файловой переменной>: textfile;

procedure AssignFile(var F: <Файловый тип>;  <Имя файла>: string);

procedure CloseFile (var F: <Файловый тип>);

Процедуры аналогичны соответственно процедурам Assign и Close.

Пример обращения к текстовым файлам приведен в проекте OptPathRDLU.


Тип «Указатель»

<Тип «Указатель»> : : = 

 ^<Тип> ;

<Тип «Указатель»> : : = 

 pointer ;

Тип «Указатель» используется для объявления переменной, которая должна содержать адрес некоторого набора данных в оперативной памяти. Таким адресом может быть либо адрес первого байта уже существующей переменной, либо адрес первого байта нового набора данных, создаваемого специально для этого предназначенной процедурой.

Существует специальное значение для указателя, имеющее имя Nil. Если указатель равен Nil, это означает, что он ни на что не указывает. Если указатель не инициализирован, нет гарантии, что он равен именно Nil.


Пример.

program P0801;

type

  pInteger = ^integer ;

  ppInteger = ^pInteger ;

  pppInteger = ^ppInteger ;

var

 p_i: ^integer ;    // Аналогично  p_i: pInteger ;

 p_b: ^boolean ;

 p_c: ^char ;

 p: pointer ;

 c: char ;

 b: boolean ;

 i: integer ;

begin

 Writeln('sizeof(p)=', sizeof(p)) ;

 Writeln('sizeof(b)=', sizeof(b)) ;

 Writeln('sizeof(i)=', sizeof(i)) ;

 Writeln('sizeof(c)=', sizeof(c)) ;

 Readln;

 b:=false ;

 Writeln(b) ;

 p_b := @b ;   // p_i := @b ;

 p := p_b ;

 p_i := p ;

 p_i^ := 7 ;

 Writeln(b) ;

 c:='A' ;

 Writeln(c) ;    { 'A' }

 p_c := @c ;

 p := p_c ;

 p_i := p ;

 p_i^ := p_i^ + 7 ;

 Writeln(c) ;    { 'H' }

 Readln ;

end.

program P0802;

type

   DateTime = record      // Delphi: TDateTime 

     Year, Month, Day, Hour, Min, Sec: word ;

   end ;

   MyRec = record

     N: longint ;

     FIO: string[40] ;

     BirthDate: DateTime ;

   end;

var

 pMyRec: ^MyRec;

 z : MyRec;

begin

 pMyRec :=nil;

 pMyRec := @z ;

 

 pMyRec^.N := 1;

 z.N := 1;

 pMyRec^.BirthDate.Year := 1999;

end.

Замечание. Подробный разговор об указателях будет продолжен позже.


Тип
pChar

Фактически:

type

 pChar = ^Char;

Тип pChar предназначен для работы со строковыми данными в формате “Zero Terminated Strings” («Строки с нулевой концовкой»). Указатель типа pChar содержит адрес «первого» байта (символа) строки. Правда, нумерацию символов принято начинать не с единицы, а с нуля. Признаком конца строки служит символ с кодом 0 (#0). Последним символом строки будет тот, сразу после которого расположен символ #0.

Строки “Zero Terminated Strings” имеют и другое название:

ASCIIZ–строки.


Пример

var

 mC: array[0..11] of char;

begin

 mC[0] := ‘N’;  mC[1] := ‘o’;  mC[2] := ‘v’;  mC[3] := ‘e’;  mC[4] := ‘m’;

 mC[5] := ‘b’;  mC[6] := ‘e’;  mC[7] := ‘r’;

 mC[8] := #0;    //  mC[8] := Chr(0);

 StrPCopy(mC, ‘November’);

end.


Процедура StrDispose

procedure StrDispose(SP: PChar);

Удаляет из динамической памяти строку. Строка размещается в динамической памяти функцией StrNew.

SP – удаляемая строка.

Если SP = nil, процедура ничего не выполняет.

Функция StrCat

function StrCat(Dest, Source: PChar): PChar;

Присоединяет к концу строки Dest строку Source. Результат – объединенная строка. Размер полученной строки не контролируется. Dest – первая строка; Source – вторая строка.

Функция StrComp

function StrComp(SPl, SP2: PChar): Integer;

Сравнивает две строки (символы сравниваются слева направо своими кодами). Результат меньше нуля, если первая строка меньше второй, равен нулю, если строки равны, и больше нуля, если первая строка больше второй.

Функция StrCopy

function StrCopy(Dest, Source: PChar): PChar;

Копирует строку Source в строку Dest. Возвращает в качестве результата новую строку Dest.

Source – копируемая строка;

Dest – строка для копирования.

Размер полученной строки не контролируется.

Функция, StrECopy

function StrECopy(Dest, Source: PChar): PChar; Копирует строку Source в строку Dest. Возвращает в качестве результата указатель на последний (нулевой) элемент строки.

Source – копируемая строка;

Dest – строка для копирования.

Размер полученной строки не контролируется.


Функция StrEnd

function StrEnd(SP: PChar): PChar;

Получает указатель на конец строки SP (на завершающий нулевой элемент).

SP – исходная строка.

Функция StrlComp

function StrLComp(SPl, SP2: PChar): PChar;

Сравнивает строки SPl и SP2 без различия между прописными и строчными латинскими буквами. Результат такой же, что и у функции StrComp.

SPl, SP2 – сравниваемые строки.


Функция
StrLCat

function StrLCat(Dest,Source: PChar; MaxLen: Word): PChar;

Добавляет в конец строки Dest MaxLen символов строки Source. Если размер

строки Source меньше MaxLen, копируется фактическое количество символов. В

качестве результата возвращает объединенную строку.

Dest – первая строка;

Source – копируемая строка;

MaxLen – число копируемых символов.

Размер полученной строки не контролируется.

Функция StrLComp

function StrLComp(SPl, SP2: PChar; MaxLen: Word): PChar;

Сравнивает MaxLen первых символов строк SPl и SP2. Если размер строк меньше MaxLen, сравнивается фактическое количество символов. Результат такой же, что и у функции StrComp.

SPl, SP2 – сравниваемые строки;

MaxLen – число сравниваемых символов.

Функция StrLCopy

function StrLCopy(Dest, Source; PChar; MaxLen: Word): PChar;

Копирует MaxLen символов строки Source в строку Desi. Если размер строки Source меньше MaxLen, копируется фактическое число символов. Результат – скопированная строка.

Dest – строка для копирования;

Source – колируемая строка;

MaxLen – число копируемых символов.

Размер полученной строки не контролируется.

Функция StrLen

function StrLen(SP: PChar): Word;

Определяет размер строки без учета заключительного символа с кодом 0.

SP – исследуемая строка.


Функция
StrLIComp

function StrLIComp(SPl, SP2: PChar; MaxLen: Word): PChar;

Сравнивает MaxLen первых символов строк SPl и SP2 без различия между прописными и строчными латинскими буквами. Если размер строк меньше MaxLen, сравнивается фактическое число символов. Результат такой же, что и у функции StrComp.

SPl,SP2 – сравниваемые строки;

MaxLen – число сравниваемых символов.

Функция StrLower

function StrLower(SP: PChar): PChar;

Преобразует в строке SP прописные латинские буквы в строчные. Результат –преобразованная строка.

SP – преобразуемая строка.


Функция StrMove

function StrMove(Dest, Source: PChar; Count: Word): PChar;

Копирует Count символов строки Source в строку Dest, даже если это число больше размера строки Source. Результат – скопированная строка.

Dest – первая строка;

Source – вторая строка. Размер полученной строки не контролируется.

Функция StrNew

function StrNew(SP: PChar): PChar;

Создает в динамической области копию строки SP. Результат – указатель на новую строку. Удаляется строка процедурой StrDispose.

SP – копируемая строка.

Функция StrPas

function StrPas(SP: PChar): string;

Преобразует ASCIIZ–строку в строку типа string. Результат – преобразованная строка.

SP – исходная строка.

Функция StrPCopy

function StrPCopy(Dest: PChar; Source: string): PChar; Преобразует строку Source типа string в ASCHZ–строку Dest. Результат – указатель на преобразованную строку.

Source – преобразуемая строка;

Dest – преобразованная строка.

Размер полученной строки не контролируется.

Функция StrPos

function StrPos(SPl, SP2: PChar): PChar;

Ищет первое вхождение строки SP2 в строку SPl. Результат – указатель на первое вхождение строки SP2 в строку SPl – либо nil, если такого вхождения нет.

SPl – строка, в которой ищется вхождение строки SP2;

SP2 – искомая строка.


Функция
StrRScan

function StrRScan(SP: PChar; Chr: Char): PChar;

Ищет последнее вхождение символа Chr в строку SP. Результат – указатель на найденный символ либо nil, если такого символа нет.

SP – строка, где ищется символ;

Chr – искомый символ.

Функция StrScan

function StrScan(SP: PChar; Chr: Char): PChar;

Ищет первое вхождение символа Chr в строку SP Результат – указатель на найденный символ либо nil, если такого символа нет.

SP – строка, где ищется символ;

Chr искомый символ.


Функция StrUpper

function StrUpper(SP: PChar): PChar;

Преобразует в строке SP строчные латинские буквы в прописные. Результат – преобразованная строка.

SP – преобразуемая строка.


Ключи компиляции (директивы компилятора)

Ключ компиляции задает режим компиляции программы. Этот режим управляет синтаксическими требованиями к исходному тексту программы,  а также поведением откомпилированного кода программы.

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

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


Выравнивание полей записей и классов

{$A+}, {$A-}, {$A1}, {$A2}, {$A4}, or {$A8}

или

{$ALIGN ON}, {$ALIGN OFF}, {$ALIGN 1}, {$ALIGN 2}, {$ALIGN 4},

or {$ALIGN 8}

По умолчанию:

{$A8}

или

{$ALIGN 8}

Зона действия: Локальный


Полное вычисление логических выражений

{$B+} or {$B-}

или

{$BOOLEVAL ON} or {$BOOLEVAL OFF}

По умолчанию:

{$B-}

или

{$BOOLEVAL OFF}

Зона действия: Локальный


Пример

x := 3;

{$B-}

if 

(x > 4)   // Вычисляется

and 

(x < 5)   // НЕ вычисляется

then  . . .  ;


Использование длинных строк
(AnsiString)

{$H+} or {$H-}

или

{$LONGSTRINGS ON} or {$LONGSTRINGS OFF}

По умолчанию:

{$H+}

или

{$LONGSTRINGS ON}

Зона действия: Локальный


Проверка результата ввода-вывода

{$I+} or {$I-}

или

{$IOCHECKS ON} or {$IOCHECKS OFF}

По умолчанию:

{$I+}

или {$IOCHECKS ON}

Зона действия: Локальный

Применён в проекте OptPathRDLU.


Разрешение использовать типизированные константы как переменные

{$J+} or {$J-}

или

{$WRITEABLECONST ON} or {$WRITEABLECONST OFF}

По умолчанию:

{$J-}

или

{$WRITEABLECONST OFF}

Зона действия: Локальный

Ключ {$J+} применён в проектах KnightTurns и OptPathRDLU.


Генерация информации о текущих типах полей, методов, свойств, объявленных в секции
Published (RTTI,  RunTime Type Information)

{$M+} or {$M-}

или

{$TYPEINFO ON} or {$TYPEINFO OFF}

По умолчанию:

{$M-}

или

{$TYPEINFO OFF}

Зона действия: Локальный

Если класс объявлен в режиме {$M-}, или не является потомком класса, объявленного в режиме {$M+}, секция Published запрещена.

Задание размера стека

{$M <Число: Мин. размер стека>, < Число: Макс. размер стека>}

или

{$MINSTACKSIZE  <Число>}

{$MAXSTACKSIZE <Число>}

По умолчанию:

{$M 16384, 1048576}

Зона действия: Глобальный

1024  <Число: Мин. размер стека>  2147483647

<Число: Мин. размер стека>  <Число: Макс. размер стека>  2147483647


Проверка выхода за пределы диапазона

{$R+} or {$R-}

или

{$RANGECHECKS ON} or {$RANGECHECKS OFF}

По умолчанию:

{$R-}

или

{$RANGECHECKS OFF}

Зона действия: Локальный


Пример
. TP7

var

 i: integer;  

 mA, nB: array[1..10] of integer;

begin

 for i := 1 to 10 do begin  mA[i] := 0; mB[i] := 0; end;

 {$R-}

 i := 12;

 mA[i] := -7;

 writeln(mA[i]);        // -7

 writeln(mB[2]);       // -7

 {$R+}

 mA[i] := -7;            // RunTime Error

 writeln(mA[12]);    // Constant Out Of Range

end.

Проверка переполнения при арифметических операциях

{$Q+} or {$Q-}

или

{$OVERFLOWCHECKS ON} or {$OVERFLOWCHECKS OFF}

По умолчанию:

{$Q-}

или

{$OVERFLOWCHECKS OFF}

Зона действия: Локальный


Пример
. TP7

var

 L: integer;

begin

 L := 2000000000;

 {$Q-}

 L := L*L;     // Реакции на переполнение нет

 writeln(L);   // -1651507200

 L := 1000000000;

 {$Q+}

 L := L*L;     // RunTime Error

end.


Разрешение использовать расширенный синтаксис

{$X+} or {$X-}

или

{$EXTENDEDSYNTAX ON} or {$EXTENDEDSYNTAX OFF}

По умолчанию:

{$X+}

или

{$EXTENDEDSYNTAX ON}

Зона действия: Глобальный


Пример
1.  TP7

{$X+}

var

 p: pChar;               // То же, что   p = ^Char;

const

 mC: array[0..39] of char = 'Petrov'#0;   // Синтаксическая ошибка при {$X-}

begin

// Во ВСЕХ последующих операторах

// будет выявлена синтаксическая ошибка при ключе {$X-}

// При ключе {$X+} код нормально компилируется и работает.

 p := 'Nikolaev';

 writeln(Ord(p[8]));  // 0

 writeln(p);

 p := @mC;

 writeln(p);

 writeln(p[0]);

end.

Пример 2.  TP7

{$X+}

uses crt;

var

 c: char;

 x, y: double;

begin

 c := readkey;

 ReadKey;     // Синтаксическая ошибка при {$X-}

 x := pi/2;  y := sin(x);

 sin(x);        // Синтаксическая ошибка в любом случае

end.


Пример
3.  Delphi

{$X+}

function Factorial(N: longint): longint;

var  i: longint;

begin

 Result := 1;     // Синтаксическая ошибка при {$X-}

 for i := 2 to N do Result := Result * i;     // Синтаксическая ошибка при {$X-}

end;


 

А также другие работы, которые могут Вас заинтересовать

14957. Қазақстанның пайдалы қазбалары 50 KB
  География және табиғат журналы №2 Наурыз – сәуір 2008 жыл Сабақтың тақырыбы: Қазақстанның пайдалы қазбалары Сабақтың мақсаты: Білімділігі: жер бедерінің дамуы және геологиялық құрылысы мен пайдалы қазбалардың байланысы ой қозғау Дамытушылық: пайдалы қ...
14958. Қазақстанның топырағы, өсімдіктері, жануарлар әлемі 58.5 KB
  Қазақстан Республикасы топырағы өсімдіктері жануарлары Қазақстанда өзге елдерде кездесетiн топырақ түрлерiнiң түгелдей дерлiгi тараған. Мұнда тайга тундра топырағына дейiн бар тек ылғалды субтропик белдемiне тән топырақ қана жоқ. Солтүстік Қазақстандағ...
14959. Қазақстанның физика-географиялық сипаттамасы 219.5 KB
  Қазақстанның физикагеографиялық сипаттамасы. Зерттелу тарихы Інұсқа Қазақстан жерінің аумағы А 2925 мың км2 В 3865 мың км2 С 27249 мың км2 Д 2525 мың км2 Е 3965 мың км2 Қазақстанның дүние жүзі бойынша жер көлемі жөнінен алатын орны А 4 В 9 С 10...
14960. Су қоры - халық байлығы 52 KB
  ӘОКС: 502.3 574 С 23 СУ ҚОРЫ – ХАЛЫҚ БАЙЛЫҒЫ Н. Е.Нұрғалиева Е.Қ . Сатаева № 42 ағылшын тілін тереңдете оқытатын орта мектебі Тараз қ. Су жүргізер тіршіліктің тамырын Су жоқ болса тіршілік тамам бауырым Судың біздер біле тұра маңызын Көп болған соң ұмытамыз қад
14961. Тіршілік эволюциясы 652.5 KB
  VІ. ТІРШІЛІК ЭВОЛЮЦИЯСЫ 4.1. Тіршілік эволюциясы Тіршілік өзі қалай дамыды Тірі затты құрайтын элементтер бірбірімен қалай бірікті Қазіргі таңда бұл сұрақтар бойынша дәйекті жорамал құруға мүмкіндік беретін мәлімет көп және жеткілікті. Тіршіліктің пайда болуы жайл...
14962. Топырақтың маңыздылығы 99.5 KB
  Топырақтың адамзат үшін маңызы Жоспар: І. Кіріспе ІІ. Негізгі бөлім 1. Топырақтың адамзат үшін маңызды. 2. Адам топырақты түзуші фактор ретінде. 3. Топырақ географиясы және егіншілік. 4. Топырақты
14963. Тұран жазығының физикалық-географиялық орыны, қалыптасуы 158 KB
  Тұран ойпатының құрылықтың ішкі аймағында орналасуы Шығыс Европаның өзі орналасқан ендіктеріне қарағанда қысы суық, жазы ыстық болып климаты шұғыл континентілігін; келуімен ерекшеленетін климатының...
14965. Химияны оқытуда халықтық педагогиканың элементтерін пайдалану 77.5 KB
  ӘОК ХИМИЯНЫ ОҚЫТУДА ХАЛЫҚТЫҚ ПЕДАГОГИКАНЫҢ ЭЛЕМЕНТТЕРІН ПАЙДАЛАНУ Д. Шардарбеков АОМКДИ Алматы қ. Тәуелсіздік алғаннан кейінгі елдің тәуелсіз әрі тегеурінді терең мазмұнды үздіксіз білім жүйесі болуы керек. Ол мемлететтің экономикалық қорғаныс қабілет