Скачать презентацию PERL 3 Основы языка Операции ввода-вывода l Скачать презентацию PERL 3 Основы языка Операции ввода-вывода l

8480fd29663e59aaa53ade5fe75e9314.ppt

  • Количество слайдов: 80

PERL. 3 Основы языка PERL. 3 Основы языка

Операции ввода-вывода l l Операция ввода команды (`dir`) Переменная $/ - определяет разделитель элементов Операции ввода-вывода l l Операция ввода команды (`dir`) Переменная $/ - определяет разделитель элементов списка l l l $/ = “”; @list=`dir`; Print $list[1], list[2];

Выполнение команды с перенаправлением вывода l l l $/ = “<KATALOG>”; $list=`dir>flist. dat`; Print Выполнение команды с перенаправлением вывода l l l $/ = “”; $list=`dir>flist. dat`; Print $list;

Операция <> l <STDIN> <STDOUT> l Perl program. pl par 1 par 2 par Операция <> l l Perl program. pl par 1 par 2 par 3… l @ARGV l

Операция <> (2) while ($line=<>){ print $line; } При передаче программе имени файла, например, Операция <> (2) while ($line=<>){ print $line; } При передаче программе имени файла, например, его же Perl ex 1. pl То программа распечатает содержимое файла

@ARGV l l l @ARGV=(“file 1. dat”, “file 2. dat”, “file 3. dat”); For @ARGV l l l @ARGV=(“file 1. dat”, “file 2. dat”, “file 3. dat”); For (; <>; ){ … } - последовательная обработка строк файлов

Упражнение l Напишите программу, которая копирует один файл в другой. Упражнение l Напишите программу, которая копирует один файл в другой.

Функции работы с файлами l l Дескриптор файла Символьная таблица имен PERL Функции работы с файлами l l Дескриптор файла Символьная таблица имен PERL

Дескриптор файла l l l Дескриптор файла в Perl-программе — это имя соединения для Дескриптор файла l l l Дескриптор файла в Perl-программе — это имя соединения для ввода-вывода между Perlпроцессом и внешним миром. Имена дескрипторов файлов похожи на имена помеченных блоков, но они берутся из другого пространства имен (поэтому у вас может быть скаляр $fred, массив $fred, хеш %fred, метка fred и дескриптор файла fred). Как и метки блоков, дескрипторы файлов используются без специального префиксного символа, поэтому их можно спутать с существующими или возможными в будущем зарезервированными словами (для команд, подпрограмм и др. ).

Открытие и закрытие дескриптора файла l l l open (File. Var, File. Name); close Открытие и закрытие дескриптора файла l l l open (File. Var, File. Name); close (File. Var); Функция Open открывает указанный файл и ассоциирует с ним файловую переменную (дескриптор файла). В зависимости от спецсимвола, стоящего перед именем файла, файл можно открыть с разным способом доступа к нему.

Открытие и закрытие дескриптора файла (2) l l l l open (FV, Открытие и закрытие дескриптора файла (2) l l l l open (FV, "FN"); Файл открыт для чтения. Запись в него запрещена. open (FV, ">FN"); Файл открыт для записи. Когда файл открыт таким способом, его содержимое автоматически стирается (а если файл не существует - создается) и в файл можно добавлять данные. open (FV, ">>FN"); Файл открыт для записи в конец. При таком способе открытия файла, тело файла не изменяется и разрешено добавлять строки в его конец. open (FV, "+

Открытие и закрытие дескриптора файла (3) l Из файла можно считать данные в виде Открытие и закрытие дескриптора файла (3) l Из файла можно считать данные в виде массива и построчно. При считывании файла построчно, какой-то переменной, при первом считывании, присваивается первая строка файла и указатель перемещается на следующую строку. Такое присваивание возвращает True. При втором считывании присваивается вторая строка, при третьем - третья и т. д. до конца файла. Когда указатель дойдет до последней строки, счетчик сбрасывается, указатель перемещается на первую строчку файла, а возвращаемое выражение становится равным False

Открытие и закрытие дескриптора файла (4) l Чтобы считать файл/строку в какую-то переменную, этой Открытие и закрытие дескриптора файла (4) l Чтобы считать файл/строку в какую-то переменную, этой переменной присваивают дескриптор файла, заключенный в треугольные скобки: l @array = ; $Var = ; l l Чтобы закрыть файл, используют функцию Close. Хотя её использование не обязательно, т. к. файл закроется сам после окончания выполнения скрипта, но желательно и является признаком хорошего стиля программирования.

Запись в тело файла l Оператору необходимо указать, в какой именно файл (может быть Запись в тело файла l Оператору необходимо указать, в какой именно файл (может быть несколько одновременно открытых файлов) следует выводить информацию, затем помещают выражение, предназначенное для вывода: l open (file, ">>file. txt"); print file «ыывпывапв"; close file; l l

Путь к файлу l l l l l D: /USR/LOCAL/APACHE |----> CGI-BIN | |----> Путь к файлу l l l l l D: /USR/LOCAL/APACHE |----> CGI-BIN | |----> MYDIR | | |----> file 0. txt | |----> script. pl | |----> file 1. txt | |----> HTDOCS |----> file 2. txt D: /USR/LOCAL/APACHE/CGI-BIN/MYDIR/file 0. txt D: /USR/LOCAL/APACHE/CGI-BIN/file 1. txt D: /USR/LOCAL/APACHE/CGI-BIN/script. pl D: /USR/LOCAL/APACHE/HTDOCS/file 3. txt MYDIR/file 0. txt file 1. txt. . /HTDOCS/file 2. txt

Блокировка файла l flock(File. Var, operation); l эта функция работает ТОЛЬКО под Unixподобными операционными Блокировка файла l flock(File. Var, operation); l эта функция работает ТОЛЬКО под Unixподобными операционными системами (Unix, Linux, Free. BSD, Sun. OS и др. ) и Windows NT, W 2 k, XP

){ print $string;" src="https://present5.com/presentation/8480fd29663e59aaa53ade5fe75e9314/image-17.jpg" alt="Блокировка файла (2) l l l open(file, "file. txt"); flock(file, LOCK_SH); while($string=){ print $string;" /> Блокировка файла (2) l l l open(file, "file. txt"); flock(file, LOCK_SH); while($string=){ print $string; } close(file);

Оператор Оператор "-X" l l Проверка файла, где 'X' - одно из ниже описанных значений. Это унарный оператор с одним аргументом - либо именем файла, либо указателем файла. Проверяет одно из условий. Если аргумент не указан, то берется значение переменной $_. Это унарный оператор с соответствующим приоритетом. Аргумент можно заключать в круглые скобки.

Оператор Оператор "-X"(2) l 'X' имеет следующие значения: l l l -r -w -x -o -R -W -X -O -e -z -s Файл разрешен на чтение эффективным uid/gid на запись -//исполнение -//принадлежит эффективному uid (идентификатор пользователя) Файл разрешен на чтение реальным uid/gid на запись -//исполнение -//принадлежит реальному uid файл существует пустой не пустой

Оператор Оператор "-X"(3) l l l -f -d -l -p -S -b -c -t -T -B -M -A обычный текст директория символическая ссылка pipes (конвейер) socket (гнездо) специальное блочное устройство -//- символьное -//указатель на уст-во tty текстовой файл двоичный "возраст" файла в днях на момент старта скрипта дней с последнего чтения

Оператор Оператор "-X"(4) l Если проверяется условие, то возвращает True при истинном утверждении и False при ложном. Код ниже проверяет наличие файла "file. txt" в текущей директории и при его наличие выводит кол-во дней с момента последнего обращения к нему: l if (-e("file. txt")){print (-A("file. txt"))} else {print "Файл не создан"}

Функция Read l l read (File. Var, скаляр, длина, смещение); read (File. Var, скаляр, Функция Read l l read (File. Var, скаляр, длина, смещение); read (File. Var, скаляр, длина); Прочитать указанное число байт из файла в скалярную переменную. Возвращает количество прочитанных байт или неопределенность при ошибке. Длина скаляра станет равной количеству считанных байт. Смещение указывают, если данные нужно поместить не с самого начала строки. Положение указателя сохраняется.

Функция Read (2) l Код ниже читает и выводит 15 байт из файла Функция Read (2) l Код ниже читает и выводит 15 байт из файла "file. txt": l open (file, "file. txt"); read("file", $u, 5); print $u, "
"; read("file", $u, 10); print $u; close file; l l l

Функция Getc l getc (File. Var); l Читает и возвращает символ из указанного файла. Функция Getc l getc (File. Var); l Читает и возвращает символ из указанного файла. Если файл не указан, то читается STDIN. После конца файла возвращает пустую строку. l Код ниже читает и выводит 15 байт из файла "file. txt": l open (file, "file. txt"); while ($u<=15){ print getc(file); } continue{$u++} close file; l l

Функция Rename l rename (старое_имя, новое_имя_файла); l Переименовать файл. Возвращает 1 в случае успеха, Функция Rename l rename (старое_имя, новое_имя_файла); l Переименовать файл. Возвращает 1 в случае успеха, иначе - 0.

Функция Unlink l unlink (список) l Удаляет файлы, указанные в списке. Возвращает количество удаленных Функция Unlink l unlink (список) l Удаляет файлы, указанные в списке. Возвращает количество удаленных файлов.

Программа, которая создает, переименовывает и удаляет файл delete. me: l print Программа, которая создает, переименовывает и удаляет файл delete. me: l print "Content-type: text/htmlnn"; l unless (-e("delete. me") or -e("undelete")){ open (file, ">delete. me") or print "Невозможно создать файл "; close file; rename ("delete. me", "undelete") and print "Удачно переименован "; unlink ("undelete") and print "Удачно удален"; } else { print" Невозможно произвести операцию!" } l l l l

Функция Utime и Truncate l Функция Utime l l l utime (Date 1, Date Функция Utime и Truncate l Функция Utime l l l utime (Date 1, Date 2, список_файлов); Изменяет дату обращения и модификации файлов из списка. Первые два элемента списка должны указывать новое значение даты обращения и модификации. Возвращает количество измененных файлов. Функция Truncate l truncate (файл, длина); l Усекает длину указанного файла.

Функция Truncate l print Функция Truncate l print "Content-type: text/htmlnn"; l $string = "This is a sample file"; print "Write to file: $string "; open (file, ">file. txt"); print file $string; close file; truncate ("file. txt", 15); open (file, "file. txt"); $string=; close file; print "Read from file: ", $string; l l l l l

Функция Tell l tell (файл); l Возвращает текущую позицию указателя в открытом файле. Если Функция Tell l tell (файл); l Возвращает текущую позицию указателя в открытом файле. Если файл не указан, то последнего читаемого файла. l Следующий код читает 15 байт из файла "file. txt". Непременное условие работы этого кода - длина файла должна быть более 15 байт. l print "

"; open (file, "file. txt"); while (tell(file) < 15){ print getc(file); } print "
"; l l l

Функция Stat l stat (файл); l Возвращает 13 элементный массив параметров указанного файла или Функция Stat l stat (файл); l Возвращает 13 элементный массив параметров указанного файла или пустой список при ошибке. Применяется обычно следующим образом: l ($dev, $ino, $mode, $nlink, $uid, $gid, $rdev, $size, $ati me, $mtime, $ctime, $blksize, $blocks) = stat($filename);

Функция Stat (2) l l l l $dev - имя устройства $ino - номер Функция Stat (2) l l l l $dev - имя устройства $ino - номер i-узла $mode - права доступа $nlink - количество связей $uid - идентификатор владельца $gid - идентификатор группы $rdev - тип устройства $size - размер файла в байтах $atime - дата последнего обращения $mtime - дата последней модификации $ctime - дата последнего изменения статуса $blksize - размер блока на диске $blocks - количество блоков в файле.

Функция Stat (3) l Следующий код выводит размер файла в байтах: l $u = Функция Stat (3) l Следующий код выводит размер файла в байтах: l $u = (stat("file. txt"))[7]; print $u; } l l

Функция Seek. Функция Chmod l Функция Seek l l l seek (File. Var, позиция, Функция Seek. Функция Chmod l Функция Seek l l l seek (File. Var, позиция, отсчет); Установить указатель на произвольную позицию в файле. Если отсчет равен 0 - позиционировать от начала файла, если 1 - от текущего положения, 2 - от конца файла. Возвращает 1 при успехе и 0 - неудаче. Функция Chmod l chmod (список); l l Изменить права доступа к файлам указанным в списке. Первый элемент в списке - числовое , обычно восьмеричное значение прав. Возвращает количество файлов которым были изменены права. Пример: l chmod 0666 'f 1', 'f 2', 'f 3';

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

Упражнение l Напишите программу, которая проверяет наличие файла index. htm в директории с HTML Упражнение l Напишите программу, которая проверяет наличие файла index. htm в директории с HTML файлами и при его наличие выдает его браузеру. l Попробуйте использовать разные способы считывания файла (посимвольный и построчный) в зависимости от передаваемого скрипту параметра.

Функции для работы с директориями l Функция Chdir l l l chdir выражение; Перейти Функции для работы с директориями l Функция Chdir l l l chdir выражение; Перейти в директорию указанную выражением. Если выражение отсутствует то перейти в "домашнюю" директорию. Возвращает true в случае успеха и false неудачи. Функция Chroot l l chroot директория; Сделать "корневой" указанную директорию. "Корневая" - значит внутри программы на нее можно ссылаться как '/'.

Функции для работы с директориями (2) l Функция Mkdir l l l mkdir директория, Функции для работы с директориями (2) l Функция Mkdir l l l mkdir директория, права; Создать директорию с указанными правами доступа. Возвращает 1 при успехе, и 0 при неудаче. Функция Opendir l l opendir указатель, выражение; Открыть директорию с именем выражения для обработки функциями readdir(), telldir(), seekdir(), rewinddir() и closedir(). Возвращает true при успехе.

Функции для работы с директориями (3) l Функция Readdir l l l readdir директория; Функции для работы с директориями (3) l Функция Readdir l l l readdir директория; Возвращает имя следующего файла в директории открытой командой opendir(). В скалярном контексте возвращает все оставшиеся имена файлов. Если файлов больше нет, то возвращает неопределенность в скалярном контексте и пустую строку в списковом. Функция Rmdir l l rmdir директория; Удалить указанную директорию, если в ней нет никаких файлов. Возвращает 1 при успехе и 0 - при неудаче. При этом переменная $! содержит код (errno).

Функции для работы с директориями (4) l Функция Seekdir l l l seekdir директория, Функции для работы с директориями (4) l Функция Seekdir l l l seekdir директория, позиция; Установить указатель файла в открытой директории для последующего чтения функцией readdir(). Текущая позиция может быть получена функцией telldir(). Функция Telldir l l telldir директория; Возвращает текущую позицию указателя в открытой директории.

Функции для работы с директориями (4) l Функция Rewindir l l rewindir директория; Устанавливает Функции для работы с директориями (4) l Функция Rewindir l l rewindir директория; Устанавливает указатель файлов открытой директории в начало для последующего чтения функцией readdir().

Встроенные переменные, получение данных методом GET l Когда сервер выполняет скрипт, для него создаются Встроенные переменные, получение данных методом GET l Когда сервер выполняет скрипт, для него создаются некоторые переменные окружения, среди которых как локальные данные (адрес скрипта на сервере, версия П/О сервера), так и данные полученные с HTTP запросом (версия браузера, IP удаленной машины и т. д. ).

Встроенные переменные l $ENV{'REQUEST_METHOD'} Это одно из самых главных полей, используемых для определения метода Встроенные переменные l $ENV{'REQUEST_METHOD'} Это одно из самых главных полей, используемых для определения метода запроса HTTP. l $ENV{'QUERY_STRING'} Это строка запроса при методе GET. l $ENV{'CONTENT_TYPE'} Тип тела запроса. l $ENV{'REMOTE_ADDR'} IP-Адрес удаленного Хоста, делающего данный запрос. l $ENV{'REMOTE_HOST'} Если запрашивающий Хост имеет доменное имя, то эта переменная содержит его, в противном случае -тот же самый IP-адресс что и REMOTE_ADDR. l $ENV{'SCRIPT_NAME'} Содержит URL адрес файла скрипта.

Встроенные переменные (2) l $ENV{'SCRIPT_FILENAME'} сервере. Полный путь к скрипту на l $ENV{'SERVER_NAME'} Имя Встроенные переменные (2) l $ENV{'SCRIPT_FILENAME'} сервере. Полный путь к скрипту на l $ENV{'SERVER_NAME'} Имя серера , чаще всего доменное как www. microsoft. com , но в редких случаях за неимением такового может быть IP-адресом. l $ENV{'SERVER_PORT'} TCP-Порт сервера использующийся для соединения. По умолчанию HTTP-порт 80, хотя может быть в некоторых случаях другим. l $ENV{'SERVER_SOFTWARE'} сервера. l $ENV{'AUTH_TYPE'}, $ENV{'REMOTE_USER'} Эти переменные определены в том случае, когда запрошенный ресурс требует аутентификации пользователя. Программное обеспечение

Встроенные переменные (3) l $ENV{'HTTP_ACCEPT'} Давая запрос на сервер браузер обычно рассчитывает получить информацию Встроенные переменные (3) l $ENV{'HTTP_ACCEPT'} Давая запрос на сервер браузер обычно рассчитывает получить информацию определенного формата, и для этого он в заголовке запроса указывает поле Accept: , Отсюда скрипту поступает список тех MIME, которые браузер готов принять в качестве ответа от сервера. l $ENV{'HTTP_USER_AGENT'} Браузер обычно посылает на сервер и информацию о себе, чтоб базируясь на знании особенностей и недостатков конкретных браузеров CGI-скрипт мог выдать информацию с учетом этого. Например, разные браузеры могут поддерживать или не поддерживать какие-то HTML тэги. l $ENV{'CONTENT_LENGTH'} Длина в байтах тела запроса. l $ENV{'GATEWAY_INTERFACE'} Версия протокола CGI. l $ENV{'SERVER_PROTOCOL'} Версия HTTP протокола сервера.

Получение данных методом GET if ($ENV{'QUERY_STRING'}**2 == 0){print $ENV{'QUERY_STRING'}} else{print $ENV{'QUERY_STRING'}**2} @array=($ENV{'SERVER_SOFTWARE'}, $ENV{'SERVER_NAME'}); @array=(@array, Получение данных методом GET if ($ENV{'QUERY_STRING'}**2 == 0){print $ENV{'QUERY_STRING'}} else{print $ENV{'QUERY_STRING'}**2} @array=($ENV{'SERVER_SOFTWARE'}, $ENV{'SERVER_NAME'}); @array=(@array, $ENV{'SCRIPT_FILENAME'}, $ENV{'HTTP_USER_A GENT'}); print "

"; foreach (@array){ print "n"; } print "
$_
"

HTML формы, функция Parse. Form l l l l &parse_form; sub parse_form { if HTML формы, функция Parse. Form l l l l &parse_form; sub parse_form { if ($ENV{'REQUEST_METHOD'} eq "POST") {$mode = 0} if ($ENV{'REQUEST_METHOD'} eq "GET") {$mode = 1} if ($mode == 0) {read(STDIN, $buffer, $ENV{'CONTENT_LENGTH'})} if ($mode == 1) {$buffer = $ENV{'QUERY_STRING'}} @pairs = split(/&/, $buffer); foreach $pair (@pairs) { ($name, $value) = split(/=/, $pair); $value =~ tr/+/ /; $value =~ s/%([a-f. A-F 0 -9])/pack("C", hex($1))/eg; $FORM{$name} = $value; } }

функция Parse. Form l l Независимо от метода передачи данных, GET или POST эта функция Parse. Form l l Независимо от метода передачи данных, GET или POST эта функция выдает данные в виде переменных вида $FORM{'значение'}. В связи с этим изменились и условия записи данных в строке URL. Теперь их следует писать в таком виде: "http: //. . . /script. pl? параметр1=значение 1 &параметр2=значение 2".

Parse. Form l print B = ", $FORM{'a'}**$FORM{'b'}; l l Эта программа выводит сумму, разность, произведение и результат возведения одного числа в другое. Вызывать программу следует таким образом: l "http: //. . . /script. pl? a=значение 1&b=значение 2", к примеру "http: //. . . /script. pl? a=256&b=2" l

Метод POST l l Суть этого метода заключается в передаче данных в теле HTTP Метод POST l l Суть этого метода заключается в передаче данных в теле HTTP запроса, а не в строке URL, как при методе GET. Это снимает ограничения на длину передаваемых данных. Длина URL не должна превышать 2048 символов. Поэтому целесообразно использовать этот метод, если вы включили в форму областью потенциально большого объема текста.

n"; print "A" src="https://present5.com/presentation/8480fd29663e59aaa53ade5fe75e9314/image-51.jpg" alt="Метод POST (2) l &parse_form; l print " n"; print "A" /> Метод POST (2) l &parse_form; l print " n"; print "A = n"; print "B = n"; print ""; print "n"; l l l l l if ($FORM{'match'} == 1){ print "A + B = ", $FORM{'a'}+$FORM{'b'}, " "; print "A - B = ", $FORM{'a'}-$FORM{'b'}, " "; print "A * B = ", $FORM{'a'}*$FORM{'b'}, " "; print "AB = ", $FORM{'a'}**$FORM{'b'}; }

Коротко о SSI l Коротко о SSI l "Server Side Includes" (включения на стороне сервера), в просторечии SSI Позволяет без лишних хлопот динамически создавать HTML файлы методом вставок. Большинство серверов поддерживают SSI. l Чтобы внутри HTML файла разместить содержание другого файл, нужно в том месте, куда предполагается вставка, поместить HTML тэг: 404 Not Found | Презентации

Oops! Page not found.

Sorry but the page you looking for cannot be found.

Better to go home

l l Хотя с помощью директивы "include virtual" можно вставлять не только статичные документы (html, txt, read. me), но и динамические (perl-скрипты, к примеру), для последних придумана специальная директива - "exec cgi". l Использование SSI позволяет оставлять всю статичную информацию в HTML странице, а динамические только включать в неё. Таким образом в браузер мы будем загружать уже не результат выполнения CGI скрипта, а HTML страницу со включеным результатом.

SSI l простейший счетчик посещений с использованием технологии SSI l #!/usr/local/bin/perl # programm 16 SSI l простейший счетчик посещений с использованием технологии SSI l #!/usr/local/bin/perl # programm 16 print "Content-Type: text/html nn"; l l l $file="counter. txt"; open(FILE, "$file"); $line=; close(FILE); open(FILE, ">$file"); $line++; print FILE "$line"; close FILE; print "$line"

SSI (2) l l Сохраните этот скрипт в файл под именем SSI (2) l l Сохраните этот скрипт в файл под именем "counter. pl". В директории с HTML файлами создайте файл "usualy. htm", в котором содержались бы такие строчки: l

Общее количество посещений: l [an error occurred while processing the directive] l

l l l l Теперь попробуйте загрузить и несколько раз обновить страницу. Вы должны увидеть, что значение каждый раз увеличивается на единицу.

Упражнение l Предусмотрите защиту файла counter. txt от ошибок ввода-вывода. Введите переменную, от значений Упражнение l Предусмотрите защиту файла counter. txt от ошибок ввода-вывода. Введите переменную, от значений которой будет зависеть, использовать или нет функцию flock.

Подпрограммы l l l Для применения подпрограммы ее необходимо определить либо в текущем модуле Подпрограммы l l l Для применения подпрограммы ее необходимо определить либо в текущем модуле (файле), либо во внешнем модуле (файле). Подпрограммы определяются и декларируются следующим образом: sub имя; - Только декларация. Определение ниже. sub имя (прототипы); - То же но с декларацией параметров. sub имя блок; - Декларация и определение. sub имя (прототипы) блок; - То же, но с параметрами.

Подпрограммы (2) l Все параметры передаются подпрограмме как массив @_. Соответственно $_[0] - первый Подпрограммы (2) l Все параметры передаются подпрограмме как массив @_. Соответственно $_[0] - первый параметр, $_[1] - второй и т. д. Массив @_ - локальный, но он содержит адреса параметров, поэтому можно изменять значение параметров. Возвращаемое значение подпрограммы - результат последнего оператора. Это может быть как скаляр так и массив. Можно принудительно возвращать результат используя функцию return(). l Подпрограмму можно вызвать, используя префикс '&' перед именем подпрограммы. Если подпрограмма предварительно продекларирована, то префикс и скобки можно опустить. l Для применения переменных доступных только внутри блока или подпрограммы необходимо определить их с помощью функции my(список). Если переменная одна, то скобки можно опустить.

Подпрограммы (3) l Процедуры и функции представляют собой важный инструмент Perl-а, позволяющий писать хорошо Подпрограммы (3) l Процедуры и функции представляют собой важный инструмент Perl-а, позволяющий писать хорошо структурированные программы. В структурированных программах обычно легко прослеживается основной алгоритм, их нетрудно понять любому читателю, они проще в отладке и менее чувствительны к ошибкам программирования. Все эти свойства являются важной особенностью процедур (функций), каждая из которых представляет собой во многом самостоятельный фрагмент кода, связанный с основной программой лишь несколькими параметрами. Самостоятельность процедур дает возможность без особых изменений в основной программе изменять код процедуры. l Процедурой в Perl называют особым образом оформленный участок кода со своим собственным именем. Упоминание этого имени в программе приводит к активации процедуры. Сразу после активации процедуры начинают выполняться входящие в неё операторы. После выполнения последнего оператора, основная программа продолжает свое выполнение дальше. l Для обмена информацией между основной программой и процедурой используются параметры вызова. Для передачи информации от процедуры программе, внутри процедуры используется оператор return.

Прототипы l l l l Для краткого описания типа передаваемых подпрограмме параметров можно применять Прототипы l l l l Для краткого описания типа передаваемых подпрограмме параметров можно применять прототипы. Если формат передаваемых данных не будет удовлетворять шаблону прототипа, это вызовет ошибку программы. В Perl существуют следующие прототипы: Декларация Пример вызова sub mylink($$) mylink $old, $new sub myvec($$$) myvec $var, $offset, 1 sub myindex($$; $) myindex &getstring, "substr" sub myreverse(@) myreverse $a, $b, $c sub myjoin($@) myjoin ": ", $a, $b, $c sub mypop(@) mypop @array sub mysplice(@$$@) mysplice @array, 0, @pushme sub mykeys(%) mykeys %{$hashref} sub myopen(*; $) myopen HANDLE, $name sub mypipe(**) mypipe READHANDLE, WRITEHANDLE sub mygrep(&@) mygrep { /foo/ } $a, $b, $c sub myrand($) myrand 42 sub mytime() mytime

Прототипы (2) l l l 'символ' - параметр с типом 'символ' '@' или '%' Прототипы (2) l l l 'символ' - параметр с типом 'символ' '@' или '%' - все оставшиеся параметры как список '$' - скаляр '&' - безымянная подпрограмма '*' - ссылка на таблицу имен '; ' - разграничитель обязательных и не обязательных параметров. l Вставить часть CGI кода в программу, подобно SSI, можно с помощью функции "require". Её синтаксис : l require "файл";

Прототипы (3) l l l l # Файл sub. pl sub summ($$){ return ($_[0]+$_[1]) Прототипы (3) l l l l # Файл sub. pl sub summ($$){ return ($_[0]+$_[1]) } # Файл со скриптом require "sub. pl"; print summ(5, 2);

Прототипы (4) l Напишем функцию, которая возвращает факториал переданного ей числа. l l sub Прототипы (4) l Напишем функцию, которая возвращает факториал переданного ей числа. l l sub fact{# объявляем функцию fact my($sum, $i); # объявляем локальные переменные $sum=1; for ($i=1; $i<=$_[0]; $i++){ $sum*=$i; } return $sum# возвращаем значение переменной $sum } l Примеры вызова такой функции: l l print fact(4); print fact(4, 22. 8, 5); l Результатом выполнения этого кода будет 24 l l l

Прототипы (5) l Чтобы избежать вызова функции с ошибочными значениями, используем прототип $, означающий, Прототипы (5) l Чтобы избежать вызова функции с ошибочными значениями, используем прототип $, означающий, что функции мы передаем только один парамер: l sub fact($){ my($sum, $i); $sum=1; for ($i=1; $i<=$_[0]; $i++){ $sum*=$i; } return $sum l l l l }

Работа с числами l Функция ABS l l Функция COS l l Возвращает косинус Работа с числами l Функция ABS l l Функция COS l l Возвращает косинус выражения в радианах Функция EXP l l Возвращает абсолютное значение выражения Возвращает e (основание натурального логарифма) в степени выражения Функция HEX l Воспринимает выражение как строку шестнадцатеричных цифр и возвращает десятичное значение

Работа с числами (2) l Функция INT l l Функция LOG l l Возвращает Работа с числами (2) l Функция INT l l Функция LOG l l Возвращает натуральный логарифм выражения Функция OCT l l Возвращает целую часть выражения Возвращает десятичное число, представленное восьмеричными цифрами Функция SCALAR l Вычисляет выражение в скалярном контексте и возвращает результат. В Perl нет специальной функции для принудительного вычисления в списковом контексте, т. к. для этого достаточно заключить его в круглые скобки

Работа с числами (3) l Функция SIN l l Функция SQRT l l Возвращает Работа с числами (3) l Функция SIN l l Функция SQRT l l Возвращает корень квадратный выражения Функция Rand l l Возвращает в радианах синус выражения Возвращает псевдослучайное число в диапазоне от 0 до значения, указанного в аргументе. Если аргумент отсутствует, то от 0 до 1. Функция Srand l Задает начальное значение для генератора случайных чисел. Если аргумент отсутствует, то используется текущее машинное время.

Функции для работы со строками l Функция Chomp l l l chomp переменная; chomp Функции для работы со строками l Функция Chomp l l l chomp переменная; chomp список; chomp; Удаляет в конце строки символ указанный переменной $/. Обычно это 'n'. Возвращает количество удаленных символов. Если переменная не указана то используется переменная $_. Если указан список то обрабатывается каждая строка списка и возвращается общее количество удаленных символов. Функция Chop l l chop переменная; chop список; chop; Полностью аналогично функции chomp но всегда удаляет последний символ строки.

Функции для работы со строками (2) l Функция Chr l l Функция Lc l Функции для работы со строками (2) l Функция Chr l l Функция Lc l l Заменить первую букву строки на малую. Функция Length l l Преобразовать строку в буквы нижнего регистра. Функция Lcfirst l l Возвращает символ с заданным ASCII кодом. Возвращает длину строки выражения. Функция Ord l Возвращает ascii код первого символа выражения.

Функции для работы со строками (3) l Функция Uc l l Функция Ucfirst l Функции для работы со строками (3) l Функция Uc l l Функция Ucfirst l l Возвращает строку выражения, в которой первая буква заменена на заглавную. Функция Substr l l Возвращает строку выражения, в которой малые буквы заменены на заглавные. substr (выражение, смещение, длина); substr (выражение, смещение); Возвращает подстроку выражения, начиная со смещения и заданной длины. Если смещение отрицательное, то отсчет ведется от конца строки. Если длина не указана, то берется все до конца строки. Функция Pack l pack (шаблон, список); l Упаковывает список в двоичную структуру по шаблону.

Шаблон l Шаблон - это строка символов, описывающая порядок и тип упакованных значений. l Шаблон l Шаблон - это строка символов, описывающая порядок и тип упакованных значений. l l l l l A - текстовая строка, добавляется пробелами. a - текстовая строка, добавляется 0 символом. b - битовая строка (возрастающая нумерация бит) B - битовая строка (убывающая нумерация бит) h - шестнадцатеричная строка ( младший байт первый) H - шестнадцатеричная строка (старший байт первый) c - символ со знаком C - символ без знака. s - короткое целое (один байт) со знаком. S - короткое целое без знака.

Шаблон l l l l i - целое (два байта) со знаком. I - Шаблон l l l l i - целое (два байта) со знаком. I - целое без знака. l - длинное целое (4 байта) со знаком. L - длинное целое без знака. n - короткое в "сетевом" формате. N - длинное в "сетевом" формате. v - короткое в "VAX" формате. V - длинное в "VAX" формате. f - single float. F - double float. p - указатель на строку ограниченную 0. P - указатель на структуру с фиксированной длиной. u - упаковка uuencode. x - нуль-байт X - резервный байт. @ - заполнить нулями позицию.

Шаблон (3) l За каждой буквой может стоять число означающее количество повторов. Для всех Шаблон (3) l За каждой буквой может стоять число означающее количество повторов. Для всех типов за исключением 'a', 'A', 'b', 'B', 'h' и 'H', упаковывается максимально возможное количество значений из списка. Символ '*' после типа означает использовать оставшиеся параметры. Тип 'a' и 'A' использует только одно значение из списка и добавляет остаток поля либо нуль-символами, либо пробелами (при распаковке по типу 'A' пробелы и нули отбрасываются, а по 'a' нет). Типы 'b' и 'B' упаковывают строку в указанное число бит. Так же как и 'h' и 'H' в число ниблов (байт). 'P' - упаковывает указатель на структуру с указанной длиной. Числа с плавающей запятой (floats и double) записываются в стандартном для каждой машины формате и могут быть разными для разных типов машин. Заметьте, что Perl всегда использует двойную точность (double), поэтому упаковка и распаковка по типу 'f' приведет к потере точности. Шаблоны для распаковки и упаковки совершенно одинаковы. l print(pack("ccc", 65, 66, 67)); # Результат ABC print(pack("A 4 A 3", "ab", "cdefg")); # "ab cde" print(pack("a 4 a 3", "ab", "cdefg")); # "ab cde" l l

Шаблон (4) l Функция Unpack l unpack (шаблон, выражение); l Функция, обратная pack(). Распаковывает Шаблон (4) l Функция Unpack l unpack (шаблон, выражение); l Функция, обратная pack(). Распаковывает строку выражения по указанному шаблону в массив значений. В скалярном контексте возвращает значение только первого элемента. Шаблоны такие же как и в pack(). l Символ '%' в шаблоне означает, что вы хотите получить вместо значения его контрольную сумму. По умолчанию - 16 -битную.

Шаблон (5) l Оператор q// l q/строка/; 'строка'; l l l Не интерполируемая строка Шаблон (5) l Оператор q// l q/строка/; 'строка'; l l l Не интерполируемая строка литералов. Если в качестве разделителя используется одинарная кавычка, ключевое слово "q" можно опускать. print q^Windows 3. 11^; # результат: Windows 3. 11 print q? Windows 98? ; # результат: Windows 98 print 'Windows 2000'; # результат: Windows 2000

Шаблон (6) l Оператор qq// l l qq/строка/; Шаблон (6) l Оператор qq// l l qq/строка/; "строка"; l Интерполируемая строка. Если в качестве разделителя используется двойная кавычка, ключевое слово "qq" можно опускать. l $var 311 = "3. 11"; # определяем переменные $var 98 = "98"; print qq#Windows $var 311#; # результат: Windows 3. 11 print qq+Windows $var 98+; # релультат: Windows 98 print "Windows 2000"; # результат: Windows 2000 l l

Шаблон (7) l Оператор qx// l l qx/строка/; `строка`; l Сначала строка интерполируется, а Шаблон (7) l Оператор qx// l l qx/строка/; `строка`; l Сначала строка интерполируется, а потом выполняется как системная команда. l print "

"; print `dir`; print "
"; l l

Шаблон (8) l Оператор qw// l qw/строка/; l Возвращает список, элементы которого содержат слова Шаблон (8) l Оператор qw// l qw/строка/; l Возвращает список, элементы которого содержат слова из строки. Т. е. пробелы рассматриваются как символыразделители. l Следующий код подчеркнет все слова фразы, длиной 7 букв: l @array = qw(Пока толстый сохнет, худой - сдохнет); foreach $i(@array){ if (length($i) == 7){print "$i "} else {print "$i "} } l l l

Шаблон (9) l Оператор Split l l split (/шаблон/, выражение, предел); split (/шаблон/, выражение); Шаблон (9) l Оператор Split l l split (/шаблон/, выражение, предел); split (/шаблон/, выражение); split (/шаблон/); split; l Разделяет строку, указанную выражением, на массив элементов и возвращает его. В скалярном контексте возвращает количество полученных элементов массива, а сам массив помещает в @_ (в списковом контексте поместить результат в @_ можно если применить ? шаблон? ) Если выражение отсутствует, то обрабатывается содержимое переменной $_. Если шаблон отсутствует, то разделителем является пробел. Все, что подходит по шаблону, считается разделителем. Если указан предел, то это максимальное число разделений. Отрицательное значение предела воспринимается как неограниченно большой предел. Если пустая строка походит под шаблон разделителя, то исходное значение разделяется посимвольно. Предел удобно использовать для частичного разделения строки. l ($a, $b, $остаток) = split(/ /, "Один Два Три Четыре", 3); l # $a = 'Один', $b = 'Два' и $остаток = 'Три Четыре'

Шаблон (10) l Если шаблон содержит круглые скобки, то символыразделители, указанные в них, вставляются Шаблон (10) l Если шаблон содержит круглые скобки, то символыразделители, указанные в них, вставляются в результирующий список как обычные элементы, причем вставляется символ, который совпал с разделителем l @a = split(/([, . ])/, "Один, Два. Три"); l # @a = ("Один", ", " , "Два", "Три") l И еще один примерчик: l @a = split(//, "червь"); l # @a = ('ч', 'е', 'р', 'в', 'ь')

Забавные ссылки l http: //www. perl. com/CPAN/misc/japh Забавные ссылки l http: //www. perl. com/CPAN/misc/japh