Perl - специальные переменные
Есть некоторые переменные, которые имеют предопределенное и особое значение в Perl. Это переменные, которые используют знаки препинания после обычного индикатора переменной ($, @ или%), например $ _ (поясняется ниже).
Большинство специальных переменных имеют длинное имя на английском языке, например, переменная ошибки операционной системы $! можно записать как $ OS_ERROR. Но если вы собираетесь использовать английский как имена, вам нужно будет поставить одну строкуuse English;в верхней части файла программы. Это поможет интерпретатору уловить точное значение переменной.
Чаще всего используется специальная переменная $ _, которая содержит строку ввода по умолчанию и строку поиска по шаблону. Например, в следующих строках -
#!/usr/bin/perl
foreach ('hickory','dickory','doc') {
print $_;
print "\n";
}
При выполнении это даст следующий результат -
hickory
dickory
doc
Опять же, давайте проверим тот же пример без явного использования переменной $ _ -
#!/usr/bin/perl
foreach ('hickory','dickory','doc') {
print;
print "\n";
}
При выполнении это также даст следующий результат -
hickory
dickory
doc
При первом выполнении цикла печатается «гикори». Во второй раз печатается «dickory», а в третий раз - «doc». Это потому, что на каждой итерации цикла текущая строка помещается в $ _ и используется по умолчанию для печати. Вот места, где Perl примет $ _, даже если вы его не укажете:
Различные унарные функции, включая такие функции, как ord и int, а также все проверки файлов (-f, -d), кроме -t, которая по умолчанию равна STDIN.
Различные функции списка, такие как печать и отключение.
Операции сопоставления с образцом m //, s /// и tr /// при использовании без оператора = ~.
Переменная итератора по умолчанию в цикле foreach, если не указана другая переменная.
Неявная переменная итератора в функциях grep и map.
Место по умолчанию для размещения входной записи, когда результат операции строкового ввода проверяется сам по себе как единственный критерий теста while (т. Е.). Обратите внимание, что за пределами проверки времени этого не произойдет.
Специальные типы переменных
В зависимости от использования и характера специальных переменных мы можем разделить их на следующие категории:
- Глобальные скалярные специальные переменные.
- Специальные переменные глобального массива.
- Специальные переменные глобального хеширования.
- Глобальные специальные дескрипторы файлов.
- Глобальные специальные константы.
- Специальные переменные регулярных выражений.
- Специальные переменные Filehandle.
Глобальные скалярные специальные переменные
Вот список всех скалярных специальных переменных. Мы перечислили соответствующие англоязычные имена вместе с символическими именами.
$ _ | Область ввода и поиска по умолчанию. |
$ ARG | |
$. | Номер текущей строки ввода последнего прочитанного дескриптора файла. Явное закрытие дескриптора файла сбрасывает номер строки. |
$ NR | |
$ / | Разделитель входной записи; перевод строки по умолчанию. Если установлена пустая строка, пустые строки рассматриваются как разделители. |
$ RS | |
$, | Разделитель поля вывода для оператора печати. |
$ OFS | |
$ \ | Разделитель выходной записи для оператора печати. |
ORS | |
$ " | Подобно «$», за исключением того, что он применяется к значениям списка, интерполированным в строку с двойными кавычками (или аналогичную интерпретируемую строку). По умолчанию это пробел. |
$ LIST_SEPARATOR | |
$; | Разделитель нижнего индекса для эмуляции многомерного массива. По умолчанию "\ 034". |
$ SUBSCRIPT_SEPARATOR | |
$ ^ L | Что выводит формат для выполнения подачи. По умолчанию "\ f". |
$ FORMAT_FORMFEED | |
$: | Текущий набор символов, после которого строка может быть разбита для заполнения полей продолжения (начиная с ^) в формате. По умолчанию "\ n" ". |
$ FORMAT_LINE_BREAK_CHARACTERS | |
$ ^ A | Текущее значение аккумулятора записи для строк формата. |
АККУМУЛЯТОР $ | |
$ # | Содержит выходной формат для печатных чисел (не рекомендуется). |
$ OFMT | |
$? | Статус, возвращаемый последним закрытием канала, командой обратной кавычки (``) или системным оператором. |
$ CHILD_ERROR | |
$! | Если используется в числовом контексте, выдает текущее значение переменной errno, идентифицируя последнюю ошибку системного вызова. Если используется в строковом контексте, выдает соответствующую строку системной ошибки. |
$ OS_ERROR или $ ERRNO | |
$ @ | Сообщение об ошибке синтаксиса Perl от последней команды eval. |
$ EVAL_ERROR | |
$$ | Pid процесса Perl, запускающего этот скрипт. |
$ PROCESS_ID или $ PID | |
$ < | Настоящий идентификатор пользователя (uid) этого процесса. |
$ REAL_USER_ID или $ UID | |
$> | Эффективный идентификатор пользователя этого процесса. |
$ EFFECTIVE_USER_ID или $ EUID | |
$ ( | Реальный идентификатор группы (gid) этого процесса. |
$ REAL_GROUP_ID или $ GID | |
$) | Эффективный гид этого процесса. |
$ EFFECTIVE_GROUP_ID или $ EGID | |
$ 0 | Содержит имя файла, содержащего исполняемый сценарий Perl. |
$ PROGRAM_NAME | |
$ [ | Индекс первого элемента в массиве и первого символа в подстроке. По умолчанию 0. |
$] | Возвращает версию плюс уровень исправления, деленный на 1000. |
$ PERL_VERSION | |
$ ^ D | Текущее значение флагов отладки. |
$ ОТЛАДКА | |
$ ^ E | Расширенное сообщение об ошибке на некоторых платформах. |
$ EXTENDED_OS_ERROR | |
$ ^ F | Максимальный дескриптор системного файла, обычно 2. |
$ SYSTEM_FD_MAX | |
$ ^ H | Содержит внутренние подсказки компилятора, разрешенные некоторыми прагматическими модулями. |
$ ^ I | Текущее значение расширения inplace-edit. Используйте undef, чтобы отключить редактирование на месте. |
$ INPLACE_EDIT | |
$ ^ M | Содержимое $ M можно использовать в качестве резервного пула памяти на случай, если Perl завершится с ошибкой нехватки памяти. Использование $ M требует специальной компиляции Perl. См. Документ INSTALL для получения дополнительной информации. |
$ ^ O | Содержит имя операционной системы, для которой был скомпилирован текущий двоичный файл Perl. |
$ OSNAME | |
$ ^ P | Внутренний флаг, который очищает отладчик, чтобы он не отлаживал сам себя. |
$ PERLDB | |
$ ^ T | Время начала выполнения сценария в секундах с начала эпохи. |
$ BASETIME | |
$ ^ W | Текущее значение переключателя предупреждения: истина или ложь. |
$ ВНИМАНИЕ | |
$ ^ X | Имя, под которым был выполнен сам двоичный файл Perl. |
$ EXECUTABLE_NAME | |
$ ARGV | Содержит имя текущего файла при чтении из <ARGV>. |
Специальные переменные глобального массива
@ARGV | Массив, содержащий аргументы командной строки, предназначенные для сценария. |
@INC | Массив, содержащий список мест для поиска скриптов Perl, которые будут оцениваться конструкциями do, require или use. |
@F | Массив, на который разделяются входные строки, если задан ключ командной строки -a. |
Специальные переменные глобального хеша
% INC | Хэш, содержащий записи для имени файла каждого файла, который был включен с помощью do или require. |
% ENV | Хеш, содержащий вашу текущую среду. |
% SIG | Хэш, используемый для установки обработчиков сигналов для различных сигналов. |
Глобальные специальные дескрипторы файлов
ARGV | Специальный дескриптор файла, который перебирает имена файлов командной строки в @ARGV. Обычно записывается как нулевой дескриптор файла в <>. |
STDERR | Специальный дескриптор файла для стандартной ошибки в любом пакете. |
STDIN | Специальный дескриптор файла для стандартного ввода в любом пакете. |
STDOUT | Специальный дескриптор файла для стандартного вывода в любом пакете. |
ДАННЫЕ | Специальный дескриптор файла, который ссылается на все, что находится после токена __END__ в файле, содержащем скрипт. Или специальный дескриптор файла для всего, что следует за токеном __DATA__ в требуемом файле, если вы читаете данные в том же пакете, в котором был найден __DATA__. |
_ (нижнее подчеркивание) | Специальный дескриптор файла, используемый для кэширования информации из последнего оператора stat, lstat или проверки файла. |
Глобальные специальные константы
__КОНЕЦ__ | Указывает на логический конец вашей программы. Любой следующий текст игнорируется, но может быть прочитан через файловый дескриптор DATA. |
__ФАЙЛ__ | Представляет имя файла в той точке вашей программы, где оно используется. Не вставляется в строки. |
__ЛИНИЯ__ | Представляет текущий номер строки. Не вставляется в строки. |
__ПАКЕТ__ | Представляет имя текущего пакета во время компиляции или undefined, если текущий пакет отсутствует. Не вставляется в строки. |
Специальные переменные регулярных выражений
цифра $ | Содержит текст, сопоставленный соответствующим набором круглых скобок в последнем сопоставленном шаблоне. Например, $ 1 соответствует тому, что содержалось в первом наборе круглых скобок в предыдущем регулярном выражении. |
$ & | Строка, соответствующая последнему успешному совпадению с шаблоном. |
$ MATCH | |
$ ` | Строка, предшествующая тому, что соответствует последнему успешному совпадению с шаблоном. |
$ PREMATCH | |
$ ' | Строка, следующая за тем, что было сопоставлено последним успешным сопоставлением с образцом. |
$ POSTMATCH | |
$ + | Последняя скобка, соответствующая последнему поисковому шаблону. Это полезно, если вы не знаете, какой из альтернативных шаблонов совпадал. Например: / Версия: (. *) | Версия: (. *) / && ($ rev = $ +); |
$ LAST_PAREN_MATCH |
Специальные переменные Filehandle
$ | | Если установлено в ненулевое значение, принудительно запускает fflush (3) после каждой записи или печати на текущем выбранном канале вывода. |
$ OUTPUT_AUTOFLUSH | |
$% | Номер текущей страницы текущего выбранного выходного канала. |
$ FORMAT_PAGE_NUMBER | |
$ = | Текущая длина страницы (печатаемых строк) текущего выбранного выходного канала. По умолчанию 60. |
$ FORMAT_LINES_PER_PAGE | |
$ - | Количество строк, оставшихся на странице текущего выбранного выходного канала. |
$ FORMAT_LINES_LEFT | |
$ ~ | Имя текущего формата отчета для текущего выбранного выходного канала. По умолчанию это имя дескриптора файла. |
$ FORMAT_NAME | |
$ ^ | Имя текущего формата верхней части страницы для текущего выбранного выходного канала. По умолчанию это имя дескриптора файла с добавлением _TOP. |
$ FORMAT_TOP_NAME |