Perl - szybki przewodnik
Perl to język programowania ogólnego przeznaczenia, pierwotnie opracowany do manipulacji tekstem, a obecnie używany do szerokiego zakresu zadań, w tym administrowania systemem, tworzenia stron internetowych, programowania sieciowego, tworzenia graficznego interfejsu użytkownika i nie tylko.
Co to jest Perl?
Perl to stabilny, wieloplatformowy język programowania.
Chociaż Perl nie jest oficjalnie akronimem, ale niewielu ludzi używało go jako Practical Extraction and Report Language.
Jest używany w projektach o znaczeniu krytycznym w sektorze publicznym i prywatnym.
Perl jest oprogramowaniem Open Source , licencjonowanym na podstawie Licencji artystycznej lub Powszechnej Licencji Publicznej GNU (GPL) .
Perl został stworzony przez Larry'ego Wall'a.
Perl 1.0 został wydany na alt.comp. Źródła usenetu w 1987 roku.
W chwili pisania tego samouczka najnowsza wersja perla to 5.16.2.
Perl jest wymieniony w Oxford English Dictionary .
PC Magazine ogłosił Perla finalistą nagrody Technical Excellence Award 1998 w kategorii Development Tool.
Funkcje Perla
Perl korzysta z najlepszych funkcji z innych języków, takich jak między innymi C, awk, sed, sh i BASIC.
Interfejs integracji bazy danych Perls DBI obsługuje bazy danych innych firm, w tym Oracle, Sybase, Postgres, MySQL i inne.
Perl współpracuje z HTML, XML i innymi językami znaczników.
Perl obsługuje Unicode.
Perl jest zgodny z Y2K.
Perl obsługuje zarówno programowanie proceduralne, jak i obiektowe.
Perl łączy się z zewnętrznymi bibliotekami C / C ++ za pośrednictwem XS lub SWIG.
Perl jest rozszerzalny. Istnieje ponad 20 000 modułów innych firm dostępnych w sieci Comprehensive Perl Archive Network ( CPAN ).
Interpreter Perla może być osadzony w innych systemach.
Perl i sieć
Perl był kiedyś najpopularniejszym językiem programowania sieciowego ze względu na jego możliwości manipulacji tekstem i szybki cykl rozwoju.
Perl jest powszechnie znany jako „ taśma klejąca Internetu ”.
Perl może obsługiwać zaszyfrowane dane internetowe, w tym transakcje e-commerce.
Perl można wbudować w serwery internetowe, aby przyspieszyć przetwarzanie nawet o 2000%.
Perl's mod_perl umożliwia serwerowi WWW Apache osadzenie interpretera Perla.
Pakiet DBI Perla ułatwia integrację z bazą danych WWW.
Perl jest interpretowany
Perl jest językiem interpretowanym, co oznacza, że kod można uruchomić w takiej postaci, w jakiej jest, bez etapu kompilacji, który tworzy nieprzenośny program wykonywalny.
Tradycyjne kompilatory konwertują programy na język maszynowy. Kiedy uruchamiasz program w Perlu, jest on najpierw kompilowany do kodu bajtowego, który jest następnie konwertowany (w trakcie działania programu) na instrukcje maszynowe. Więc to nie jest to samo, co muszle lub Tcl, które sąstrictly interpretowane bez reprezentacji pośredniej.
Nie jest też podobny do większości wersji C lub C ++, które są kompilowane bezpośrednio do formatu zależnego od komputera. Jest gdzieś pomiędzy, wraz z Pythonem i awk i plików Emacs .elc.
Zanim zaczniemy pisać nasze programy w Perlu, przyjrzyjmy się, jak skonfigurować nasze środowisko Perla. Perl jest dostępny na wielu różnych platformach -
- Unix (Solaris, Linux, FreeBSD, AIX, HP / UX, SunOS, IRIX itp.)
- Win 9x / NT / 2000 /
- WinCE
- Macintosh (PPC, 68K)
- Solaris (x86, SPARC)
- OpenVMS
- Alpha (7.2 i nowsze)
- Symbian
- Debian GNU / kFreeBSD
- MirOS BSD
- I wiele więcej...
Jest to bardziej prawdopodobne, że w Twoim systemie będzie zainstalowany perl. Po prostu spróbuj podać następujące polecenie w wierszu polecenia $ -
$perl -v
Jeśli masz zainstalowany perl na swoim komputerze, otrzymasz następujący komunikat -
This is perl 5, version 16, subversion 2 (v5.16.2) built for i686-linux
Copyright 1987-2012, Larry Wall
Perl may be copied only under the terms of either the Artistic License or the
GNU General Public License, which may be found in the Perl 5 source kit.
Complete documentation for Perl, including FAQ lists, should be found on
this system using "man perl" or "perldoc perl". If you have access to the
Internet, point your browser at http://www.perl.org/, the Perl Home Page.
Jeśli nie masz jeszcze zainstalowanego perla, przejdź do następnej sekcji.
Pobieranie instalacji Perla
Najbardziej aktualny kod źródłowy, pliki binarne, dokumentacja, wiadomości itp. Są dostępne na oficjalnej stronie Perla.
Perl Official Website - https://www.perl.org/
Dokumentację Perla można pobrać z następującej witryny.
Perl Documentation Website - https://perldoc.perl.org
Zainstaluj Perl
Dystrybucja Perla jest dostępna na wiele różnych platform. Musisz pobrać tylko kod binarny odpowiedni dla Twojej platformy i zainstalować Perl.
Jeśli kod binarny dla Twojej platformy nie jest dostępny, potrzebujesz kompilatora C do ręcznej kompilacji kodu źródłowego. Kompilowanie kodu źródłowego zapewnia większą elastyczność pod względem wyboru funkcji wymaganych w instalacji.
Oto krótki przegląd instalacji Perla na różnych platformach.
Instalacja w systemach Unix i Linux
Oto proste kroki instalacji Perla na komputerze z systemem Unix / Linux.
Otwórz przeglądarkę internetową i przejdź do https://www.perl.org/get.html.
Kliknij łącze, aby pobrać spakowany kod źródłowy dostępny dla systemów Unix / Linux.
Pobieranie perl-5.x.y.tar.gz plik i wydaj następujące polecenia po znaku zachęty $.
$tar -xzf perl-5.x.y.tar.gz
$cd perl-5.x.y $./Configure -de
$make $make test
$make install
NOTE - Tutaj $ to znak zachęty systemu Unix, w którym wpisujesz swoje polecenie, więc upewnij się, że nie wpisujesz $ podczas wpisywania wyżej wymienionych poleceń.
Spowoduje to zainstalowanie Perla w standardowej lokalizacji / usr / local / bin, a jego biblioteki zostaną zainstalowane w / usr / local / lib / perlXX , gdzie XX jest wersją Perla, której używasz.
Skompilowanie kodu źródłowego zajmie trochę czasu po wydaniu pliku makeKomenda. Po zakończeniu instalacji możesz wydaćperl -vpolecenie w $ prompt, aby sprawdzić instalację perla. Jeśli wszystko jest w porządku, wyświetli się komunikat taki, jak pokazaliśmy powyżej.
Instalacja systemu Windows
Oto kroki instalacji Perla na komputerze z systemem Windows.
Kliknij łącze do instalacji Strawberry Perl w systemie Windows http://strawberryperl.com
Pobierz 32-bitową lub 64-bitową wersję instalacji.
Uruchom pobrany plik, klikając go dwukrotnie w Eksploratorze Windows. Pojawi się kreator instalacji Perla, który jest naprawdę łatwy w użyciu. Po prostu zaakceptuj ustawienia domyślne, poczekaj, aż instalacja się zakończy i możesz rozpocząć pracę!
Instalacja na komputerze Macintosh
Aby zbudować własną wersję Perla, będziesz potrzebować polecenia „make”, które jest częścią narzędzi programistycznych Apples, zwykle dostarczanych z instalacyjnymi dyskami DVD z systemem Mac OS. Nie potrzebujesz najnowszej wersji Xcode (za którą jest teraz pobierana opłata) do zainstalowania make.
Oto proste kroki instalacji Perla na komputerze z systemem Mac OS X.
Otwórz przeglądarkę internetową i przejdź do https://www.perl.org/get.html.
Kliknij łącze, aby pobrać spakowany kod źródłowy dostępny dla systemu Mac OS X.
Pobieranie perl-5.x.y.tar.gz plik i wydaj następujące polecenia po znaku zachęty $.
$tar -xzf perl-5.x.y.tar.gz
$cd perl-5.x.y $./Configure -de
$make $make test
$make install
Spowoduje to zainstalowanie Perla w standardowej lokalizacji / usr / local / bin, a jego biblioteki zostaną zainstalowane w / usr / local / lib / perlXX , gdzie XX jest wersją Perla, której używasz.
Uruchamianie Perla
Poniżej przedstawiono różne sposoby uruchamiania Perla.
Interaktywny tłumacz
Możesz wejść perli od razu rozpocznij kodowanie w interaktywnym interpretatorze, uruchamiając go z wiersza poleceń. Możesz to zrobić z systemu Unix, DOS lub dowolnego innego systemu, który zapewnia interpreter wiersza poleceń lub okno powłoki.
$perl -e <perl code> # Unix/Linux
or
C:>perl -e <perl code> # Windows/DOS
Oto lista wszystkich dostępnych opcji wiersza poleceń -
Sr.No. | Opcja i opis |
---|---|
1 | -d[:debugger] Uruchamia program w debugerze |
2 | -Idirectory Określa katalog dołączony @ INC / # |
3 | -T Umożliwia kontrolę plam |
4 | -t Włącza skalowanie ostrzeżeń |
5 | -U Umożliwia niebezpieczne operacje |
6 | -w Włącza wiele przydatnych ostrzeżeń |
7 | -W Włącza wszystkie ostrzeżenia |
8 | -X Wyłącza wszystkie ostrzeżenia |
9 | -e program Uruchamia skrypt Perla przesłany jako program |
10 | file Uruchamia skrypt Perla z podanego pliku |
Skrypt z wiersza poleceń
Skrypt Perla to plik tekstowy, który przechowuje w nim kod Perla i może być wykonywany z wiersza poleceń, wywołując interpreter w aplikacji, jak poniżej -
$perl script.pl # Unix/Linux
or
C:>perl script.pl # Windows/DOS
Zintegrowane środowisko programistyczne
Możesz także uruchomić Perl ze środowiska graficznego interfejsu użytkownika (GUI). Wszystko, czego potrzebujesz, to aplikacja GUI w systemie, która obsługuje Perl. Możesz pobrać Padre, Perl IDE . Możesz także użyć Eclipse Plugin EPIC - Edytor Perl i IDE dla Eclipse, jeśli znasz Eclipse.
Przed przejściem do następnego rozdziału upewnij się, że środowisko jest odpowiednio skonfigurowane i działa idealnie. Jeśli nie jesteś w stanie poprawnie skonfigurować środowiska, możesz skorzystać z pomocy administratora systemu.
Wszystkie przykłady podane w kolejnych rozdziałach zostały wykonane w wersji 5.16.2 dostępnej w wersji CentOS Linuksa.
Perl zapożycza składnię i koncepcje z wielu języków: awk, sed, C, Bourne Shell, Smalltalk, Lisp, a nawet z angielskiego. Istnieją jednak pewne wyraźne różnice między językami. Ten rozdział ma na celu szybkie zapoznanie Cię ze składnią, której oczekuje się w Perlu.
Program w Perlu składa się z sekwencji deklaracji i instrukcji, które biegną od góry do dołu. Pętle, podprogramy i inne struktury sterujące umożliwiają przeskakiwanie w obrębie kodu. Każda prosta instrukcja musi kończyć się średnikiem (;).
Perl jest językiem o dowolnej formie: możesz go formatować i wcinać, jak chcesz. Białe znaki służą głównie do oddzielania tokenów, w przeciwieństwie do języków takich jak Python, gdzie jest ważną częścią składni, lub Fortran, gdzie jest nieistotny.
Pierwszy program w Perlu
Programowanie w trybie interaktywnym
Możesz użyć interpretera Perla z -eopcja w wierszu poleceń, która umożliwia wykonywanie instrukcji Perl z wiersza poleceń. Spróbujmy czegoś po znaku zachęty $ w następujący sposób -
$perl -e 'print "Hello World\n"'
To wykonanie da następujący wynik -
Hello, world
Programowanie w trybie skryptowym
Zakładając, że jesteś już w znaku zachęty $, otwórzmy plik tekstowy hello.pl za pomocą edytora vi lub vim i umieść następujące wiersze wewnątrz pliku.
#!/usr/bin/perl
# This will print "Hello, World"
print "Hello, world\n";
Tutaj /usr/bin/perljest w rzeczywistości plik binarny interpretera perla. Zanim wykonasz swój skrypt, upewnij się, że zmieniłeś tryb pliku skryptu i nadaj uprawnienia do wykonywania, ogólnie ustawienie 0755 działa idealnie, a na końcu wykonujesz powyższy skrypt w następujący sposób -
$chmod 0755 hello.pl $./hello.pl
To wykonanie da następujący wynik -
Hello, world
Możesz użyć nawiasów dla argumentów funkcji lub pominąć je według własnego gustu. Są one wymagane tylko od czasu do czasu, aby wyjaśnić kwestie dotyczące pierwszeństwa. Kolejne dwie instrukcje dają ten sam wynik.
print("Hello, world\n");
print "Hello, world\n";
Rozszerzenie pliku Perl
Skrypt Perla można utworzyć w dowolnym zwykłym edytorze tekstu prostego. Istnieje kilka programów dostępnych dla każdego typu platformy. Istnieje wiele programów przeznaczonych dla programistów do pobrania w sieci.
Zgodnie z konwencją Perla, plik Perla musi być zapisany z rozszerzeniem .pl lub .PL, aby został rozpoznany jako działający skrypt Perla. Nazwy plików mogą zawierać cyfry, symbole i litery, ale nie mogą zawierać spacji. Użyj podkreślenia (_) w miejscach spacji.
Komentarze w Perlu
Komentarze w dowolnym języku programowania są przyjaciółmi programistów. Komentarze mogą być używane w celu uczynienia programu przyjaznym dla użytkownika i są po prostu pomijane przez interpretera bez wpływu na funkcjonalność kodu. Na przykład w powyższym programie linia zaczynająca się od hasha# to komentarz.
Po prostu mówiąc, komentarze w Perlu zaczynają się od symbolu krzyżyka i biegną do końca linii -
# This is a comment in perl
Wiersze zaczynające się od = są interpretowane jako początek sekcji osadzonej dokumentacji (pod), a wszystkie kolejne wiersze aż do elementu next = cut są ignorowane przez kompilator. Oto przykład -
#!/usr/bin/perl
# This is a single line comment
print "Hello, world\n";
=begin comment
This is all part of multiline comment.
You can use as many lines as you like
These comments will be ignored by the
compiler until the next =cut is encountered.
=cut
To da następujący wynik -
Hello, world
Białe spacje w Perlu
Program w Perlu nie dba o białe znaki. Poniższy program działa doskonale -
#!/usr/bin/perl
print "Hello, world\n";
Ale jeśli spacje znajdują się wewnątrz cytowanych ciągów, zostaną wydrukowane tak, jak są. Na przykład -
#!/usr/bin/perl
# This would print with a line break in the middle
print "Hello
world\n";
To da następujący wynik -
Hello
world
Wszystkie rodzaje białych znaków, takie jak spacje, tabulatory, znaki nowej linii itp., Są równoważne interpreterowi, jeśli są używane poza cudzysłowami. Linia zawierająca tylko białe spacje, ewentualnie z komentarzem, jest nazywana pustą linią i Perl całkowicie ją ignoruje.
Pojedyncze i podwójne cytaty w Perlu
Możesz używać podwójnych cudzysłowów lub pojedynczych cudzysłowów wokół ciągów literałów w następujący sposób -
#!/usr/bin/perl
print "Hello, world\n";
print 'Hello, world\n';
To da następujący wynik -
Hello, world
Hello, world\n$
Istnieje ważna różnica między pojedynczymi i podwójnymi cudzysłowami. Tylko cudzysłowyinterpolatezmienne i znaki specjalne, takie jak znaki nowej linii \ n, podczas gdy pojedynczy cudzysłów nie interpoluje żadnej zmiennej ani znaku specjalnego. Sprawdź poniższy przykład, w którym używamy $ a jako zmiennej do przechowywania wartości, a później drukujemy tę wartość -
#!/usr/bin/perl
$a = 10; print "Value of a = $a\n";
print 'Value of a = $a\n';
To da następujący wynik -
Value of a = 10
Value of a = $a\n$
Dokumenty „Tutaj”
Możesz wygodnie przechowywać lub drukować tekst wielowierszowy. Nawet ty możesz użyć zmiennych wewnątrz dokumentu „tutaj”. Poniżej znajduje się prosta składnia, sprawdź dokładnie, czy nie może być spacji między znakiem << a identyfikatorem.
Identyfikator może być gołym słowem lub cytowanym tekstem, tak jak użyliśmy poniżej EOF. Jeśli identyfikator jest cytowany, rodzaj cytatu, którego używasz, określa sposób traktowania tekstu wewnątrz dokumentu, tak jak w zwykłym cytowaniu. Identyfikator bez cudzysłowu działa jak cudzysłowy.
#!/usr/bin/perl
$a = 10;
$var = <<"EOF"; This is the syntax for here document and it will continue until it encounters a EOF in the first line. This is case of double quote so variable value will be interpolated. For example value of a = $a
EOF
print "$var\n"; $var = <<'EOF';
This is case of single quote so variable value will be
interpolated. For example value of a = $a EOF print "$var\n";
To da następujący wynik -
This is the syntax for here document and it will continue
until it encounters a EOF in the first line.
This is case of double quote so variable value will be
interpolated. For example value of a = 10
This is case of single quote so variable value will be
interpolated. For example value of a = $a
Uciekające postacie
Perl używa znaku ukośnika odwrotnego (\) do zmiany znaczenia dowolnego typu znaku, który może kolidować z naszym kodem. Weźmy jeden przykład, w którym chcemy wypisać podwójny cudzysłów i znak $ -
#!/usr/bin/perl
$result = "This is \"number\""; print "$result\n";
print "\$result\n";
To da następujący wynik -
This is "number"
$result
Identyfikatory Perla
Identyfikator Perla to nazwa używana do identyfikacji zmiennej, funkcji, klasy, modułu lub innego obiektu. Nazwa zmiennej Perla zaczyna się od $, @ lub%, po których następuje zero lub więcej liter, podkreśleń i cyfr (od 0 do 9).
Perl nie zezwala na znaki interpunkcyjne, takie jak @, $ i% w identyfikatorach. Perl jestcase sensitivejęzyk programowania. A zatem$Manpower i $manpower to dwa różne identyfikatory w Perlu.
Perl jest językiem o luźnych typach i nie ma potrzeby określania typu danych podczas używania go w programie. Interpreter Perla wybierze typ na podstawie kontekstu samych danych.
Perl ma trzy podstawowe typy danych: skalary, tablice skalarów i skróty skalarów, znane również jako tablice asocjacyjne. Oto kilka szczegółów na temat tych typów danych.
Sr.No. | Rodzaje i opis |
---|---|
1 | Scalar Skalary to proste zmienne. Poprzedza je znak dolara ($). Skalar to liczba, łańcuch lub odniesienie. Odsyłacz to właściwie adres zmiennej, o czym przekonamy się w kolejnych rozdziałach. |
2 | Arrays Tablice to uporządkowane listy skalarów, do których uzyskujesz dostęp z indeksem numerycznym rozpoczynającym się od 0. Są one poprzedzone znakiem „at” (@). |
3 | Hashes Hashe to nieuporządkowane zestawy par klucz / wartość, do których uzyskujesz dostęp za pomocą kluczy jako indeksów dolnych. Są poprzedzone znakiem procentu (%). |
Literały numeryczne
Perl przechowuje wszystkie liczby wewnętrznie jako liczby całkowite ze znakiem lub wartości zmiennoprzecinkowe o podwójnej precyzji. Literały liczbowe są określane w dowolnym z następujących formatów zmiennoprzecinkowych lub całkowitych -
Rodzaj | Wartość |
---|---|
Liczba całkowita | 1234 |
Ujemna liczba całkowita | -100 |
Punkt zmiennoprzecinkowy | 2000 |
Notacja naukowa | 16.12E14 |
Szesnastkowy | 0xffff |
Ósemkowe | 0577 |
Literały strunowe
Łańcuchy to sekwencje znaków. Zwykle są to wartości alfanumeryczne oddzielone cudzysłowami pojedynczymi (') lub podwójnymi ("). Działają podobnie jak cudzysłowy powłoki UNIX, w których można używać ciągów w apostrofach i podwójnych cudzysłowach.
Literały łańcuchowe w podwójnych cudzysłowach pozwalają na interpolację zmiennych, a ciągi w apostrofach nie. Istnieją pewne znaki poprzedzone ukośnikiem, mają specjalne znaczenie i są używane do reprezentowania jak nowa linia (\ n) lub tabulacja (\ t).
Możesz osadzić znaki nowej linii lub dowolną z następujących sekwencji Escape bezpośrednio w swoich podwójnych cudzysłowach -
Sekwencja ewakuacyjna | Znaczenie |
---|---|
\\ | Ukośnik wsteczny |
\ ' | Pojedynczy cudzysłów |
\ " | Cudzysłów |
\za | Alert lub dzwonek |
\b | Backspace |
\fa | Form feed |
\ n | Nowa linia |
\ r | Powrót karetki |
\ t | Zakładka pozioma |
\ v | Zakładka pionowa |
\ 0nn | Tworzy liczby w formacie ósemkowym |
\ xnn | Tworzy liczby w formacie szesnastkowym |
\ cX | Znaki kontrolne, x może być dowolnym znakiem |
\ u | Wymusza następną wielką literę |
\ l | Wymusza na następnym znaku małe litery |
\ U | Wymusza pisanie wielkich liter we wszystkich kolejnych znakach |
\ L | Wymusza małe litery we wszystkich kolejnych znakach |
\ Q | Wszystkie kolejne znaki niealfanumeryczne należy ułożyć ukośnikiem odwrotnym |
\MI | End \ U, \ L lub \ Q |
Przykład
Zobaczmy jeszcze raz, jak zachowują się ciągi znaków w przypadku pojedynczego i podwójnego cudzysłowu. Tutaj użyjemy znaków ucieczki wymienionych w powyższej tabeli i użyjemy zmiennej skalarnej do przypisania wartości ciągów.
#!/usr/bin/perl
# This is case of interpolation.
$str = "Welcome to \ntutorialspoint.com!";
print "$str\n"; # This is case of non-interpolation. $str = 'Welcome to \ntutorialspoint.com!';
print "$str\n"; # Only W will become upper case. $str = "\uwelcome to tutorialspoint.com!";
print "$str\n"; # Whole line will become capital. $str = "\UWelcome to tutorialspoint.com!";
print "$str\n"; # A portion of line will become capital. $str = "Welcome to \Ututorialspoint\E.com!";
print "$str\n"; # Backsalash non alpha-numeric including spaces. $str = "\QWelcome to tutorialspoint's family";
print "$str\n";
To da następujący wynik -
Welcome to
tutorialspoint.com!
Welcome to \ntutorialspoint.com!
Welcome to tutorialspoint.com!
WELCOME TO TUTORIALSPOINT.COM!
Welcome to TUTORIALSPOINT.com!
Welcome\ to\ tutorialspoint\'s\ family
Zmienne to zarezerwowane miejsca w pamięci do przechowywania wartości. Oznacza to, że kiedy tworzysz zmienną, rezerwujesz trochę miejsca w pamięci.
Na podstawie typu danych zmiennej interpreter przydziela pamięć i decyduje, co może być przechowywane w zarezerwowanej pamięci. Dlatego przypisując różne typy danych do zmiennych, można przechowywać w tych zmiennych liczby całkowite, dziesiętne lub łańcuchy.
Dowiedzieliśmy się, że Perl ma następujące trzy podstawowe typy danych -
- Scalars
- Arrays
- Hashes
W związku z tym będziemy używać trzech typów zmiennych w Perlu. ZAscalarzmienna będzie poprzedzona znakiem dolara ($) i może przechowywać liczbę, ciąg znaków lub referencję. Naarrayzmienna będzie poprzedzona znakiem @ i będzie przechowywać uporządkowane listy skalarów. W końcuHash zmienna będzie poprzedzona znakiem% i będzie używana do przechowywania zestawów par klucz / wartość.
Perl utrzymuje każdy typ zmiennej w oddzielnej przestrzeni nazw. Możesz więc bez obawy o konflikt użyć tej samej nazwy dla zmiennej skalarnej, tablicy lub skrótu. Oznacza to, że $ foo i @foo to dwie różne zmienne.
Tworzenie zmiennych
Zmienne Perla nie muszą być jawnie deklarowane, aby zarezerwować miejsce w pamięci. Deklaracja jest wykonywana automatycznie po przypisaniu wartości do zmiennej. Znak równości (=) służy do przypisywania wartości zmiennym.
Zwróć uwagę, że jest to obowiązkowe, aby zadeklarować zmienną przed jej użyciem, jeśli używamy use strict oświadczenie w naszym programie.
Operand po lewej stronie operatora = to nazwa zmiennej, a operand po prawej stronie operatora = to wartość przechowywana w zmiennej. Na przykład -
$age = 25; # An integer assignment
$name = "John Paul"; # A string $salary = 1445.50; # A floating point
Tutaj 25, „John Paul” i 1445,50 to wartości przypisane odpowiednio do zmiennych $ age , $ name i $ płac . Wkrótce zobaczymy, jak możemy przypisać wartości do tablic i skrótów.
Zmienne skalarne
Skalar to pojedyncza jednostka danych. Te dane mogą być liczbą całkowitą, zmiennoprzecinkową, znakiem, łańcuchem, akapitem lub całą stroną internetową. Mówiąc prosto, może to być cokolwiek, ale tylko jedna rzecz.
Oto prosty przykład użycia zmiennych skalarnych -
#!/usr/bin/perl
$age = 25; # An integer assignment
$name = "John Paul"; # A string $salary = 1445.50; # A floating point
print "Age = $age\n"; print "Name = $name\n";
print "Salary = $salary\n";
To da następujący wynik -
Age = 25
Name = John Paul
Salary = 1445.5
Zmienne tablicowe
Tablica to zmienna przechowująca uporządkowaną listę wartości skalarnych. Zmienne tablicowe są poprzedzone znakiem „at” (@). Aby odnieść się do pojedynczego elementu tablicy, użyjesz znaku dolara ($) z nazwą zmiennej, po której nastąpi indeks elementu w nawiasach kwadratowych.
Oto prosty przykład użycia zmiennych tablicowych -
#!/usr/bin/perl
@ages = (25, 30, 40);
@names = ("John Paul", "Lisa", "Kumar");
print "\$ages[0] = $ages[0]\n";
print "\$ages[1] = $ages[1]\n";
print "\$ages[2] = $ages[2]\n";
print "\$names[0] = $names[0]\n";
print "\$names[1] = $names[1]\n";
print "\$names[2] = $names[2]\n";
Tutaj użyliśmy znaku ucieczki (\) przed znakiem $, aby go wydrukować. Inne Perl zrozumie to jako zmienną i wypisze jej wartość. Po uruchomieniu da to następujący wynik -
$ages[0] = 25
$ages[1] = 30 $ages[2] = 40
$names[0] = John Paul $names[1] = Lisa
$names[2] = Kumar
Hash Variables
Hash to zestaw key/valuepary. Zmienne z haszowaniem są poprzedzone znakiem procentu (%). Aby odnieść się do pojedynczego elementu hasha, użyjesz nazwy zmiennej hash, po której nastąpi „klucz” powiązany z wartością w nawiasach klamrowych.
Oto prosty przykład użycia zmiennych hash -
#!/usr/bin/perl
%data = ('John Paul', 45, 'Lisa', 30, 'Kumar', 40);
print "\$data{'John Paul'} = $data{'John Paul'}\n"; print "\$data{'Lisa'} = $data{'Lisa'}\n"; print "\$data{'Kumar'} = $data{'Kumar'}\n";
To da następujący wynik -
$data{'John Paul'} = 45
$data{'Lisa'} = 30 $data{'Kumar'} = 40
Zmienny kontekst
Perl traktuje tę samą zmienną inaczej w zależności od kontekstu, tj. Sytuacji, w której zmienna jest używana. Sprawdźmy następujący przykład -
#!/usr/bin/perl
@names = ('John Paul', 'Lisa', 'Kumar');
@copy = @names;
$size = @names; print "Given names are : @copy\n"; print "Number of names are : $size\n";
To da następujący wynik -
Given names are : John Paul Lisa Kumar
Number of names are : 3
Tutaj @names to tablica, która była używana w dwóch różnych kontekstach. Najpierw skopiowaliśmy go do innej tablicy, tj. Listy, więc zwrócił wszystkie elementy, zakładając, że kontekst jest kontekstem listy. Następnie użyliśmy tej samej tablicy i próbowaliśmy zapisać tę tablicę w postaci skalarnej, więc w tym przypadku zwróciła ona tylko liczbę elementów w tej tablicy, zakładając, że kontekst jest kontekstem skalarnym. Poniższa tabela zawiera listę różnych kontekstów -
Sr.No. | Kontekst i opis |
---|---|
1 | Scalar Przypisanie do zmiennej skalarnej oblicza prawą stronę w kontekście skalarnym. |
2 | List Przypisanie do tablicy lub skrótu oblicza prawą stronę w kontekście listowym. |
3 | Boolean Kontekst logiczny to po prostu każde miejsce, w którym wyrażenie jest oceniane w celu sprawdzenia, czy jest prawdziwe, czy fałszywe. |
4 | Void This context not only doesn't care what the return value is, it doesn't even want a return value. |
5 | Interpolative This context only happens inside quotes, or things that work like quotes. |
A scalar is a single unit of data. That data might be an integer number, floating point, a character, a string, a paragraph, or an entire web page.
Here is a simple example of using scalar variables −
#!/usr/bin/perl
$age = 25; # An integer assignment $name = "John Paul"; # A string
$salary = 1445.50; # A floating point print "Age = $age\n";
print "Name = $name\n"; print "Salary = $salary\n";
This will produce the following result −
Age = 25
Name = John Paul
Salary = 1445.5
Numeric Scalars
A scalar is most often either a number or a string. Following example demonstrates the usage of various types of numeric scalars −
#!/usr/bin/perl
$integer = 200; $negative = -300;
$floating = 200.340; $bigfloat = -1.2E-23;
# 377 octal, same as 255 decimal
$octal = 0377; # FF hex, also 255 decimal $hexa = 0xff;
print "integer = $integer\n"; print "negative = $negative\n";
print "floating = $floating\n"; print "bigfloat = $bigfloat\n";
print "octal = $octal\n"; print "hexa = $hexa\n";
This will produce the following result −
integer = 200
negative = -300
floating = 200.34
bigfloat = -1.2e-23
octal = 255
hexa = 255
String Scalars
Following example demonstrates the usage of various types of string scalars. Notice the difference between single quoted strings and double quoted strings −
#!/usr/bin/perl
$var = "This is string scalar!"; $quote = 'I m inside single quote - $var'; $double = "This is inside single quote - $var"; $escape = "This example of escape -\tHello, World!";
print "var = $var\n"; print "quote = $quote\n";
print "double = $double\n"; print "escape = $escape\n";
This will produce the following result −
var = This is string scalar!
quote = I m inside single quote - $var
double = This is inside single quote - This is string scalar!
escape = This example of escape - Hello, World
Scalar Operations
You will see a detail of various operators available in Perl in a separate chapter, but here we are going to list down few numeric and string operations.
#!/usr/bin/perl
$str = "hello" . "world"; # Concatenates strings.
$num = 5 + 10; # adds two numbers. $mul = 4 * 5; # multiplies two numbers.
$mix = $str . $num; # concatenates string and number. print "str = $str\n";
print "num = $num\n"; print "mix = $mix\n";
This will produce the following result −
str = helloworld
num = 15
mul = 20
mix = helloworld15
Multiline Strings
If you want to introduce multiline strings into your programs, you can use the standard single quotes as below −
#!/usr/bin/perl
$string = 'This is a multiline string'; print "$string\n";
This will produce the following result −
This is
a multiline
string
You can use "here" document syntax as well to store or print multilines as below −
#!/usr/bin/perl
print <<EOF;
This is
a multiline
string
EOF
This will also produce the same result −
This is
a multiline
string
V-Strings
A literal of the form v1.20.300.4000 is parsed as a string composed of characters with the specified ordinals. This form is known as v-strings.
A v-string provides an alternative and more readable way to construct strings, rather than use the somewhat less readable interpolation form "\x{1}\x{14}\x{12c}\x{fa0}".
They are any literal that begins with a v and is followed by one or more dot-separated elements. For example −
#!/usr/bin/perl
$smile = v9786; $foo = v102.111.111;
$martin = v77.97.114.116.105.110; print "smile = $smile\n";
print "foo = $foo\n"; print "martin = $martin\n";
This will also produce the same result −
smile = ☺
foo = foo
martin = Martin
Wide character in print at main.pl line 7.
Special Literals
So far you must have a feeling about string scalars and its concatenation and interpolation opration. So let me tell you about three special literals __FILE__, __LINE__, and __PACKAGE__ represent the current filename, line number, and package name at that point in your program.
They may be used only as separate tokens and will not be interpolated into strings. Check the below example −
#!/usr/bin/perl
print "File name ". __FILE__ . "\n";
print "Line Number " . __LINE__ ."\n";
print "Package " . __PACKAGE__ ."\n";
# they can not be interpolated
print "__FILE__ __LINE__ __PACKAGE__\n";
This will produce the following result −
File name hello.pl
Line Number 4
Package main
__FILE__ __LINE__ __PACKAGE__
An array is a variable that stores an ordered list of scalar values. Array variables are preceded by an "at" (@) sign. To refer to a single element of an array, you will use the dollar sign ($) with the variable name followed by the index of the element in square brackets.
Here is a simple example of using the array variables −
#!/usr/bin/perl
@ages = (25, 30, 40);
@names = ("John Paul", "Lisa", "Kumar");
print "\$ages[0] = $ages[0]\n"; print "\$ages[1] = $ages[1]\n"; print "\$ages[2] = $ages[2]\n"; print "\$names[0] = $names[0]\n"; print "\$names[1] = $names[1]\n"; print "\$names[2] = $names[2]\n";
Here we have used the escape sign (\) before the $ sign just to print it. Other Perl will understand it as a variable and will print its value. When executed, this will produce the following result −
$ages[0] = 25 $ages[1] = 30
$ages[2] = 40 $names[0] = John Paul
$names[1] = Lisa $names[2] = Kumar
In Perl, List and Array terms are often used as if they're interchangeable. But the list is the data, and the array is the variable.
Array Creation
Array variables are prefixed with the @ sign and are populated using either parentheses or the qw operator. For example −
@array = (1, 2, 'Hello');
@array = qw/This is an array/;
The second line uses the qw// operator, which returns a list of strings, separating the delimited string by white space. In this example, this leads to a four-element array; the first element is 'this' and last (fourth) is 'array'. This means that you can use different lines as follows −
@days = qw/Monday
Tuesday
...
Sunday/;
You can also populate an array by assigning each value individually as follows −
$array[0] = 'Monday'; ... $array[6] = 'Sunday';
Accessing Array Elements
When accessing individual elements from an array, you must prefix the variable with a dollar sign ($) and then append the element index within the square brackets after the name of the variable. For example −
#!/usr/bin/perl
@days = qw/Mon Tue Wed Thu Fri Sat Sun/;
print "$days[0]\n";
print "$days[1]\n"; print "$days[2]\n";
print "$days[6]\n"; print "$days[-1]\n";
print "$days[-7]\n";
This will produce the following result −
Mon
Tue
Wed
Sun
Sun
Mon
Array indices start from zero, so to access the first element you need to give 0 as indices. You can also give a negative index, in which case you select the element from the end, rather than the beginning, of the array. This means the following −
print $days[-1]; # outputs Sun
print $days[-7]; # outputs Mon
Sequential Number Arrays
Perl offers a shortcut for sequential numbers and letters. Rather than typing out each element when counting to 100 for example, we can do something like as follows −
#!/usr/bin/perl
@var_10 = (1..10);
@var_20 = (10..20);
@var_abc = (a..z);
print "@var_10\n"; # Prints number from 1 to 10
print "@var_20\n"; # Prints number from 10 to 20
print "@var_abc\n"; # Prints number from a to z
Here double dot (..) is called range operator. This will produce the following result −
1 2 3 4 5 6 7 8 9 10
10 11 12 13 14 15 16 17 18 19 20
a b c d e f g h i j k l m n o p q r s t u v w x y z
Array Size
The size of an array can be determined using the scalar context on the array - the returned value will be the number of elements in the array −
@array = (1,2,3);
print "Size: ",scalar @array,"\n";
The value returned will always be the physical size of the array, not the number of valid elements. You can demonstrate this, and the difference between scalar @array and $#array, using this fragment is as follows −
#!/usr/bin/perl
@array = (1,2,3);
$array[50] = 4; $size = @array;
$max_index = $#array;
print "Size: $size\n"; print "Max Index: $max_index\n";
This will produce the following result −
Size: 51
Max Index: 50
There are only four elements in the array that contains information, but the array is 51 elements long, with a highest index of 50.
Adding and Removing Elements in Array
Perl provides a number of useful functions to add and remove elements in an array. You may have a question what is a function? So far you have used print function to print various values. Similarly there are various other functions or sometime called sub-routines, which can be used for various other functionalities.
Sr.No. | Types & Description |
---|---|
1 | push @ARRAY, LIST Pushes the values of the list onto the end of the array. |
2 | pop @ARRAY Pops off and returns the last value of the array. |
3 | shift @ARRAY Shifts the first value of the array off and returns it, shortening the array by 1 and moving everything down. |
4 | unshift @ARRAY, LIST Prepends list to the front of the array, and returns the number of elements in the new array. |
#!/usr/bin/perl
# create a simple array
@coins = ("Quarter","Dime","Nickel");
print "1. \@coins = @coins\n";
# add one element at the end of the array
push(@coins, "Penny");
print "2. \@coins = @coins\n";
# add one element at the beginning of the array
unshift(@coins, "Dollar");
print "3. \@coins = @coins\n";
# remove one element from the last of the array.
pop(@coins);
print "4. \@coins = @coins\n";
# remove one element from the beginning of the array.
shift(@coins);
print "5. \@coins = @coins\n";
This will produce the following result −
1. @coins = Quarter Dime Nickel
2. @coins = Quarter Dime Nickel Penny
3. @coins = Dollar Quarter Dime Nickel Penny
4. @coins = Dollar Quarter Dime Nickel
5. @coins = Quarter Dime Nickel
Slicing Array Elements
You can also extract a "slice" from an array - that is, you can select more than one item from an array in order to produce another array.
#!/usr/bin/perl
@days = qw/Mon Tue Wed Thu Fri Sat Sun/;
@weekdays = @days[3,4,5];
print "@weekdays\n";
This will produce the following result −
Thu Fri Sat
The specification for a slice must have a list of valid indices, either positive or negative, each separated by a comma. For speed, you can also use the .. range operator −
#!/usr/bin/perl
@days = qw/Mon Tue Wed Thu Fri Sat Sun/;
@weekdays = @days[3..5];
print "@weekdays\n";
This will produce the following result −
Thu Fri Sat
Replacing Array Elements
Now we are going to introduce one more function called splice(), which has the following syntax −
splice @ARRAY, OFFSET [ , LENGTH [ , LIST ] ]
This function will remove the elements of @ARRAY designated by OFFSET and LENGTH, and replaces them with LIST, if specified. Finally, it returns the elements removed from the array. Following is the example −
#!/usr/bin/perl
@nums = (1..20);
print "Before - @nums\n";
splice(@nums, 5, 5, 21..25);
print "After - @nums\n";
This will produce the following result −
Before - 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
After - 1 2 3 4 5 21 22 23 24 25 11 12 13 14 15 16 17 18 19 20
Here, the actual replacement begins with the 6th number after that five elements are then replaced from 6 to 10 with the numbers 21, 22, 23, 24 and 25.
Transform Strings to Arrays
Let's look into one more function called split(), which has the following syntax −
split [ PATTERN [ , EXPR [ , LIMIT ] ] ]
This function splits a string into an array of strings, and returns it. If LIMIT is specified, splits into at most that number of fields. If PATTERN is omitted, splits on whitespace. Following is the example −
#!/usr/bin/perl
# define Strings
$var_string = "Rain-Drops-On-Roses-And-Whiskers-On-Kittens"; $var_names = "Larry,David,Roger,Ken,Michael,Tom";
# transform above strings into arrays.
@string = split('-', $var_string); @names = split(',', $var_names);
print "$string[3]\n"; # This will print Roses print "$names[4]\n"; # This will print Michael
This will produce the following result −
Roses
Michael
Transform Arrays to Strings
We can use the join() function to rejoin the array elements and form one long scalar string. This function has the following syntax −
join EXPR, LIST
This function joins the separate strings of LIST into a single string with fields separated by the value of EXPR, and returns the string. Following is the example −
#!/usr/bin/perl
# define Strings
$var_string = "Rain-Drops-On-Roses-And-Whiskers-On-Kittens"; $var_names = "Larry,David,Roger,Ken,Michael,Tom";
# transform above strings into arrays.
@string = split('-', $var_string); @names = split(',', $var_names);
$string1 = join( '-', @string ); $string2 = join( ',', @names );
print "$string1\n"; print "$string2\n";
This will produce the following result −
Rain-Drops-On-Roses-And-Whiskers-On-Kittens
Larry,David,Roger,Ken,Michael,Tom
Sorting Arrays
The sort() function sorts each element of an array according to the ASCII Numeric standards. This function has the following syntax −
sort [ SUBROUTINE ] LIST
This function sorts the LIST and returns the sorted array value. If SUBROUTINE is specified then specified logic inside the SUBTROUTINE is applied while sorting the elements.
#!/usr/bin/perl
# define an array
@foods = qw(pizza steak chicken burgers);
print "Before: @foods\n";
# sort this array
@foods = sort(@foods);
print "After: @foods\n";
This will produce the following result −
Before: pizza steak chicken burgers
After: burgers chicken pizza steak
Please note that sorting is performed based on ASCII Numeric value of the words. So the best option is to first transform every element of the array into lowercase letters and then perform the sort function.
Merging Arrays
Because an array is just a comma-separated sequence of values, you can combine them together as shown below −
#!/usr/bin/perl
@numbers = (1,3,(4,5,6));
print "numbers = @numbers\n";
This will produce the following result −
numbers = 1 3 4 5 6
The embedded arrays just become a part of the main array as shown below −
#!/usr/bin/perl
@odd = (1,3,5);
@even = (2, 4, 6);
@numbers = (@odd, @even);
print "numbers = @numbers\n";
This will produce the following result −
numbers = 1 3 5 2 4 6
Selecting Elements from Lists
The list notation is identical to that for arrays. You can extract an element from an array by appending square brackets to the list and giving one or more indices −
#!/usr/bin/perl
$var = (5,4,3,2,1)[4]; print "value of var = $var\n"
This will produce the following result −
value of var = 1
Podobnie możemy wyodrębnić plasterki, chociaż bez konieczności stosowania wiodącego znaku @ -
#!/usr/bin/perl
@list = (5,4,3,2,1)[1..3];
print "Value of list = @list\n";
To da następujący wynik -
Value of list = 4 3 2
Hash to zestaw key/valuepary. Zmienne z haszowaniem są poprzedzone znakiem procentu (%). Aby odnieść się do pojedynczego elementu hasha, użyjesz nazwy zmiennej hash poprzedzonej znakiem „$”, a po niej „klucz” powiązany z wartością w nawiasach klamrowych.
Oto prosty przykład użycia zmiennych hash -
#!/usr/bin/perl
%data = ('John Paul', 45, 'Lisa', 30, 'Kumar', 40);
print "\$data{'John Paul'} = $data{'John Paul'}\n"; print "\$data{'Lisa'} = $data{'Lisa'}\n"; print "\$data{'Kumar'} = $data{'Kumar'}\n";
To da następujący wynik -
$data{'John Paul'} = 45
$data{'Lisa'} = 30 $data{'Kumar'} = 40
Tworzenie skrótów
Hashe są tworzone na jeden z dwóch następujących sposobów. W pierwszej metodzie przypisujesz wartość do nazwanego klucza pojedynczo -
$data{'John Paul'} = 45; $data{'Lisa'} = 30;
$data{'Kumar'} = 40;
W drugim przypadku używasz listy, która jest konwertowana poprzez pobieranie poszczególnych par z listy: pierwszy element pary jest używany jako klucz, a drugi jako wartość. Na przykład -
%data = ('John Paul', 45, 'Lisa', 30, 'Kumar', 40);
Dla jasności możesz użyć => jako aliasu dla, aby wskazać pary klucz / wartość w następujący sposób -
%data = ('John Paul' => 45, 'Lisa' => 30, 'Kumar' => 40);
Oto jeszcze jeden wariant powyższego formularza, spójrz na niego, tutaj wszystkie klucze zostały poprzedzone myślnikiem (-) i wokół nich nie jest wymagany cytat -
%data = (-JohnPaul => 45, -Lisa => 30, -Kumar => 40);
Ale ważne jest, aby pamiętać, że istnieje jedno słowo, tj. Klucze bez spacji zostały użyte w tej formie tworzenia skrótu i jeśli zbudujesz swój hash w ten sposób, dostęp do kluczy będzie możliwy tylko przy użyciu łącznika, jak pokazano poniżej.
$val = %data{-JohnPaul}
$val = %data{-Lisa}
Dostęp do elementów skrótu
Podczas uzyskiwania dostępu do poszczególnych elementów za pomocą skrótu, należy poprzedzić zmienną znakiem dolara ($), a następnie dołączyć klucz elementu w nawiasach klamrowych po nazwie zmiennej. Na przykład -
#!/usr/bin/perl
%data = ('John Paul' => 45, 'Lisa' => 30, 'Kumar' => 40);
print "$data{'John Paul'}\n"; print "$data{'Lisa'}\n";
print "$data{'Kumar'}\n";
To da następujący wynik -
45
30
40
Wydobywanie plasterków
Możesz wyodrębnić plasterki skrótu tak samo, jak wyodrębnić plasterki z tablicy. Będziesz musiał użyć przedrostka @ dla zmiennej, aby zapisać zwróconą wartość, ponieważ będzie to lista wartości -
#!/uer/bin/perl
%data = (-JohnPaul => 45, -Lisa => 30, -Kumar => 40);
@array = @data{-JohnPaul, -Lisa};
print "Array : @array\n";
To da następujący wynik -
Array : 45 30
Wyodrębnianie kluczy i wartości
Możesz uzyskać listę wszystkich kluczy z skrótu, używając keys funkcja, która ma następującą składnię -
keys %HASH
Ta funkcja zwraca tablicę wszystkich kluczy z podanego skrótu. Oto przykład -
#!/usr/bin/perl
%data = ('John Paul' => 45, 'Lisa' => 30, 'Kumar' => 40);
@names = keys %data;
print "$names[0]\n";
print "$names[1]\n"; print "$names[2]\n";
To da następujący wynik -
Lisa
John Paul
Kumar
Podobnie możesz użyć valuesfunkcja, aby uzyskać listę wszystkich wartości. Ta funkcja ma następującą składnię -
values %HASH
Ta funkcja zwraca zwykłą tablicę składającą się ze wszystkich wartości podanego skrótu. Oto przykład -
#!/usr/bin/perl
%data = ('John Paul' => 45, 'Lisa' => 30, 'Kumar' => 40);
@ages = values %data;
print "$ages[0]\n"; print "$ages[1]\n";
print "$ages[2]\n";
To da następujący wynik -
30
45
40
Sprawdzanie istnienia
Jeśli spróbujesz uzyskać dostęp do pary klucz / wartość z skrótu, który nie istnieje, zwykle otrzymasz plik undefinedwartość, a jeśli ostrzeżenia są włączone, otrzymasz ostrzeżenie wygenerowane w czasie wykonywania. Możesz to obejść, używającexists funkcja, która zwraca prawdę, jeśli podany klucz istnieje, niezależnie od jego wartości -
#!/usr/bin/perl
%data = ('John Paul' => 45, 'Lisa' => 30, 'Kumar' => 40);
if( exists($data{'Lisa'} ) ) {
print "Lisa is $data{'Lisa'} years old\n";
} else {
print "I don't know age of Lisa\n";
}
W tym miejscu przedstawiliśmy stwierdzenie IF ... ELSE, które omówimy w osobnym rozdziale. Na razie po prostu to zakładaszif( condition ) część zostanie wykonana tylko wtedy, gdy podany warunek będzie spełniony, inaczej elseczęść zostanie wykonana. Więc kiedy wykonujemy powyższy program, daje on następujący wynik, ponieważ tutaj podany warunek istnieje ($ data {'Lisa'} zwraca true -
Lisa is 30 years old
Pobieranie rozmiaru skrótu
Możesz uzyskać rozmiar - to znaczy liczbę elementów z skrótu, używając kontekstu skalarnego dla kluczy lub wartości. Mówiąc prosto, najpierw musisz uzyskać tablicę kluczy lub wartości, a następnie możesz uzyskać rozmiar tablicy w następujący sposób -
#!/usr/bin/perl
%data = ('John Paul' => 45, 'Lisa' => 30, 'Kumar' => 40);
@keys = keys %data;
$size = @keys; print "1 - Hash size: is $size\n";
@values = values %data;
$size = @values; print "2 - Hash size: is $size\n";
To da następujący wynik -
1 - Hash size: is 3
2 - Hash size: is 3
Dodaj i usuń elementy w hashach
Dodanie nowej pary klucz / wartość można wykonać za pomocą jednej linii kodu przy użyciu prostego operatora przypisania. Ale aby usunąć element z skrótu, musisz użyćdelete funkcja, jak pokazano poniżej w przykładzie -
#!/usr/bin/perl
%data = ('John Paul' => 45, 'Lisa' => 30, 'Kumar' => 40);
@keys = keys %data;
$size = @keys; print "1 - Hash size: is $size\n";
# adding an element to the hash;
$data{'Ali'} = 55; @keys = keys %data; $size = @keys;
print "2 - Hash size: is $size\n"; # delete the same element from the hash; delete $data{'Ali'};
@keys = keys %data;
$size = @keys; print "3 - Hash size: is $size\n";
To da następujący wynik -
1 - Hash size: is 3
2 - Hash size: is 4
3 - Hash size: is 3
Instrukcje warunkowe Perla pomagają w podejmowaniu decyzji, które wymagają, aby programista określił jeden lub więcej warunków, które mają być ocenione lub przetestowane przez program, wraz z instrukcją lub instrukcjami do wykonania, jeśli warunek zostanie określony jako prawdziwy, i opcjonalnie inne instrukcje do wykonania, jeśli warunek zostanie określony jako fałszywy.
Poniżej znajduje się ogólny zarys typowej struktury podejmowania decyzji występującej w większości języków programowania -
Liczba 0, ciągi „0” i „”, pusta lista () i undef to wszystko false w kontekście logicznym i wszystkie inne wartości są true. Negacja prawdziwej wartości przez! lub not zwraca specjalną wartość false.
Język programowania Perl udostępnia następujące typy instrukcji warunkowych.
Sr.No. | Oświadczenie i opis |
---|---|
1 | jeśli oświadczenie Na if statement składa się z wyrażenia logicznego, po którym następuje co najmniej jedna instrukcja. |
2 | if ... else oświadczenie Na if statement może następować opcjonalnie else statement. |
3 | if ... elsif ... else oświadczenie Na if statement może następować opcjonalnie elsif statement a następnie opcjonalnie else statement. |
4 | chyba że oświadczenie Na unless statement składa się z wyrażenia logicznego, po którym następuje co najmniej jedna instrukcja. |
5 | chyba że ... inne oświadczenie Na unless statement może następować opcjonalnie else statement. |
6 | chyba że ... elsif..else oświadczenie Na unless statement może następować opcjonalnie elsif statement a następnie opcjonalnie else statement. |
7 | instrukcja przełączania W najnowszych wersjach Perla możesz korzystać z switchkomunikat. co pozwala w prosty sposób porównać wartość zmiennej z różnymi warunkami. |
The? : Operator
Sprawdźmy conditional operator ? :które można wykorzystać do wymiany if...elsesprawozdania. Ma następującą ogólną postać -
Exp1 ? Exp2 : Exp3;
Gdzie Exp1, Exp2 i Exp3 to wyrażenia. Zwróć uwagę na użycie i położenie okrężnicy.
Wartość? wyrażenie jest określane w następujący sposób: Exp1 jest oceniane. Jeśli to prawda, to Exp2 jest obliczane i staje się wartością całości? wyrażenie. Jeśli Exp1 ma wartość false, to Exp3 jest oceniane, a jego wartość staje się wartością wyrażenia. Poniżej znajduje się prosty przykład wykorzystujący ten operator -
#!/usr/local/bin/perl
$name = "Ali"; $age = 10;
$status = ($age > 60 )? "A senior citizen" : "Not a senior citizen";
print "$name is - $status\n";
To da następujący wynik -
Ali is - Not a senior citizen
Może zaistnieć sytuacja, w której trzeba będzie kilkakrotnie wykonać blok kodu. Ogólnie instrukcje są wykonywane sekwencyjnie: pierwsza instrukcja funkcji jest wykonywana jako pierwsza, po niej następuje druga i tak dalej.
Języki programowania zapewniają różne struktury kontrolne, które pozwalają na bardziej skomplikowane ścieżki wykonywania.
Instrukcja pętli pozwala nam wielokrotnie wykonać instrukcję lub grupę instrukcji, a następująca po niej jest ogólną postacią instrukcji pętli w większości języków programowania -
Język programowania Perl udostępnia następujące typy pętli do obsługi wymagań dotyczących pętli.
Sr.No. | Typ i opis pętli |
---|---|
1 | pętla while Powtarza instrukcję lub grupę instrukcji, gdy dany warunek jest prawdziwy. Testuje warunek przed wykonaniem treści pętli. |
2 | aż do pętli Powtarza stwierdzenie lub grupę instrukcji, aż dany warunek stanie się prawdziwy. Testuje warunek przed wykonaniem treści pętli. |
3 | dla pętli Wykonuje sekwencję instrukcji wiele razy i skraca kod zarządzający zmienną pętli. |
4 | pętla foreach Pętla foreach wykonuje iterację po normalnej wartości listy i ustawia zmienną VAR jako każdy element listy po kolei. |
5 | zrobić ... pętla while Podobnie jak instrukcja while, z tą różnicą, że testuje warunek na końcu treści pętli |
6 | pętle zagnieżdżone Możesz użyć jednej lub więcej pętli wewnątrz dowolnej innej pętli while, for lub do..while. |
Instrukcje sterowania pętlą
Instrukcje sterujące pętlą zmieniają wykonanie z jego normalnej sekwencji. Gdy wykonanie opuszcza zakres, wszystkie automatyczne obiekty utworzone w tym zakresie są niszczone.
Perl obsługuje następujące instrukcje sterujące. Kliknij poniższe łącza, aby sprawdzić ich szczegóły.
Sr.No. | Oświadczenie i opis kontroli |
---|---|
1 | następne oświadczenie Powoduje, że pętla pomija pozostałą część swojego ciała i natychmiast ponownie testuje swój stan przed ponownym powtórzeniem. |
2 | ostanie oswiadczenie Kończy instrukcję pętli i przenosi wykonanie do instrukcji bezpośrednio po pętli. |
3 | kontynuuj oświadczenie Kontynuacja BLOKU, jest zawsze wykonywana tuż przed ponownym obliczeniem warunku. |
4 | instrukcja ponownego wykonania Polecenie redo restartuje blok pętli bez ponownego oceniania warunku. Blok kontynuacji, jeśli istnieje, nie jest wykonywany. |
5 | instrukcja goto Perl obsługuje polecenie goto w trzech postaciach: goto label, goto expr oraz goto & name. |
Nieskończona pętla
Pętla staje się nieskończoną pętlą, jeśli warunek nigdy nie staje się fałszywy. Plikforpętla jest tradycyjnie używana do tego celu. Ponieważ żadne z trzech wyrażeń tworzących rozszerzeniefor pętli są wymagane, możesz utworzyć nieskończoną pętlę, pozostawiając puste wyrażenie warunkowe.
#!/usr/local/bin/perl
for( ; ; ) {
printf "This loop will run forever.\n";
}
Możesz zakończyć powyższą nieskończoną pętlę, naciskając klawisze Ctrl + C.
W przypadku braku wyrażenia warunkowego przyjmuje się, że jest ono prawdziwe. Możesz mieć wyrażenie inicjujące i inkrementujące, ale jako programista częściej używaj konstrukcji for (;;) do oznaczania nieskończonej pętli.
Co to jest operator?
Prostej odpowiedzi można udzielić za pomocą wyrażenia 4 + 5 równa się 9 . Tutaj 4 i 5 nazywamy operandami, a + nazywamy operatorem. Język Perl obsługuje wiele typów operatorów, ale poniżej znajduje się lista ważnych i najczęściej używanych operatorów -
- Operatory arytmetyczne
- Operatory równości
- Operatory logiczne
- Operatory przypisania
- Operatory bitowe
- Operatory logiczne
- Operatory podobne do kwotowań
- Różni operatorzy
Przyjrzyjmy się kolejno wszystkim operatorom.
Operatory arytmetyczne Perla
Przyjmij zmienną $a holds 10 and variable $b zawiera 20, a następnie znajdują się operatory arytmatyczne Perla -
Pokaż przykład
Sr.No. | Operator i opis |
---|---|
1 | + ( Addition ) Dodaje wartości po obu stronach operatora Example - $a + $b da 30 |
2 | - (Subtraction) Odejmuje operand po prawej stronie od operandu po lewej stronie Example - $a - $b da -10 |
3 | * (Multiplication) Mnoży wartości po obu stronach operatora Example - $a * $b da 200 |
4 | / (Division) Dzieli operand lewej ręki przez operand prawej ręki Example - $b / $a da 2 |
5 | % (Modulus) Dzieli operand po lewej stronie przez operand po prawej stronie i zwraca resztę Example - $b % $a da 0 |
6 | ** (Exponent) Wykonuje obliczenia wykładnicze (potęgowe) na operatorach Example - $a**$b da 10 do potęgi 20 |
Operatory równości Perla
Nazywa się je również operatorami relacyjnymi. Przyjmij zmienną$a holds 10 and variable $b zawiera zatem 20, sprawdźmy następujące numeryczne operatory równości -
Pokaż przykład
Sr.No. | Operator i opis |
---|---|
1 | == (equal to) Sprawdza, czy wartości dwóch operandów są równe, czy nie, jeśli tak, warunek staje się prawdziwy. Example - ($a == $b) nie jest prawdą. |
2 | != (not equal to) Sprawdza, czy wartości dwóch operandów są równe, czy nie, jeśli wartości nie są równe, warunek staje się prawdziwy. Example - ($a != $b) jest prawdą. |
3 | <=> Sprawdza, czy wartości dwóch operandów są równe, czy nie, i zwraca wartość -1, 0 lub 1 w zależności od tego, czy lewy argument jest liczbowo mniejszy, równy lub większy niż prawy argument. Example - ($a <=> $b) zwraca -1. |
4 | > (greater than) Sprawdza, czy wartość lewego operandu jest większa niż wartość prawego operandu, jeśli tak, warunek staje się prawdziwy. Example - ($a > $b) nie jest prawdą. |
5 | < (less than) Sprawdza, czy wartość lewego operandu jest mniejsza niż wartość prawego operandu. Jeśli tak, warunek staje się prawdziwy. Example - ($a < $b) jest prawdą. |
6 | >= (greater than or equal to) Sprawdza, czy wartość lewego operandu jest większa lub równa wartości prawego operandu, jeśli tak, warunek staje się prawdziwy. Example - ($a >= $b) nie jest prawdą. |
7 | <= (less than or equal to) Sprawdza, czy wartość lewego operandu jest mniejsza lub równa wartości prawego operandu, jeśli tak, warunek staje się prawdziwy. Example - ($a <= $b) jest prawdą. |
Poniżej znajduje się lista operatorów kapitałowych. Przyjmij zmienną$a holds "abc" and variable $b zawiera wtedy "xyz", sprawdźmy następujące operatory równości łańcuchów -
Pokaż przykład
Sr.No. | Operator i opis |
---|---|
1 | lt Zwraca prawdę, jeśli lewy argument jest mniejszy niż prawy argument. Example - ($a lt $b) jest prawdą. |
2 | gt Zwraca prawdę, jeśli lewy argument jest ciągiem większy niż prawy argument. Example - ($a gt $b) jest fałszywa. |
3 | le Zwraca prawdę, jeśli lewy argument jest ciągowo mniejszy lub równy prawemu argumentowi. Example - ($a le $b) jest prawdą. |
4 | ge Zwraca prawdę, jeśli lewy argument jest ciągiem większy lub równy prawemu argumentowi. Example - ($a ge $b) jest fałszywa. |
5 | eq Zwraca prawdę, jeśli lewy argument jest ciągiem równy prawemu argumentowi. Example - ($a eq $b) jest fałszywa. |
6 | ne Zwraca wartość true, jeśli lewy argument nie jest równy prawemu argumentowi. Example - ($a ne $b) jest prawdą. |
7 | cmp Zwraca wartość -1, 0 lub 1 w zależności od tego, czy lewy argument jest ciągiem mniejszy niż, równy lub większy niż prawy argument. Example - ($a cmp $b) wynosi -1. |
Operatory przypisania Perla
Przyjmij zmienną $a holds 10 and variable $b zawiera 20, poniżej znajdują się operatory przypisania dostępne w Perlu i ich użycie -
Pokaż przykład
Sr.No. | Operator i opis |
---|---|
1 | = Prosty operator przypisania, przypisuje wartości z operandów po prawej stronie do operandów po lewej stronie Example - $c = $a + $b will assigned value of $a + $b into $do |
2 | += Dodaj operator przypisania AND, dodaje prawy operand do lewego operandu i przypisuje wynik do lewego operandu Example - $c += $a jest równoważne $c = $c + $ a |
3 | -= Operator odejmowania AND przypisania, Odejmuje prawy operand od lewego operandu i przypisuje wynik do lewego operandu Example - $ c - = $a is equivalent to $c = $c - $za |
4 | *= Operator mnożenia AND przypisania, Mnoży prawy operand przez lewy operand i przypisuje wynik do lewego operandu Example - $c *= $a jest równoważne $c = $c * $ a |
5 | /= Operator podziału AND przypisania, dzieli lewy operand z prawym operandem i przypisuje wynik do lewego operandu Example - $ c / = $a is equivalent to $c = $c / $za |
6 | %= Operator przypisania modułu AND, pobiera moduł przy użyciu dwóch operandów i przypisuje wynik do lewego operandu Example - $c %= $a jest równoważne $c = $c% a |
7 | **= Operator przypisania wykładnika AND, wykonuje obliczenia wykładnicze (potęgowe) na operatorach i przypisuje wartość do lewego operandu Example - $c **= $a jest równoważne $c = $c ** $ a |
Operatory bitowe Perla
Operator bitowy działa na bitach i wykonuje operacje bit po bicie. Załóżmy, że $ a = 60; i $ b = 13; Teraz w formacie binarnym będą one następujące -
$ a = 0011 1100
$ b = 0000 1101
-----------------
$ a & $ b = 0000 1100
$ a | $ b = 0011 1101
$ a ^ $ b = 0011 0001
~ $ a = 1100 0011
Istnieją następujące operatory bitowe obsługiwane przez język Perl, załóżmy, że $a = 60; and $b = 13
Pokaż przykład
Sr.No. | Operator i opis |
---|---|
1 | & Operator binarny AND kopiuje trochę do wyniku, jeśli istnieje w obu operandach. Example - ($a & $b) da 12, czyli 0000 1100 |
2 | | Operator binarny OR kopiuje bit, jeśli istnieje w operandzie. Example - ($a | $b) da 61, czyli 0011 1101 |
3 | ^ Binarny operator XOR kopiuje bit, jeśli jest ustawiony w jednym operandzie, ale nie w obu. Example - ($a ^ $b) da 49, czyli 0011 0001 |
4 | ~ Operator dopełniacza binarnego jest jednoargumentowy i ma efekt „odwracania” bitów. Example - (~ $ a) da -61, czyli 1100 0011 w postaci uzupełnienia do 2 ze względu na liczbę binarną ze znakiem. |
5 | << Binarny operator przesunięcia w lewo. Wartość lewych operandów jest przesuwana w lewo o liczbę bitów określoną przez prawy operand. Example - $ a << 2 da 240, czyli 1111 0000 |
6 | >> Binarny operator przesunięcia w prawo. Wartość lewego operandu jest przesuwana w prawo o liczbę bitów określoną przez prawy operand. Example - $ a >> 2 daje 15, czyli 0000 1111 |
Operatory logiczne Perla
Istnieją następujące operatory logiczne obsługiwane przez język Perl. Załóżmy, że zmienna $ a zawiera prawdę, a zmienna $ b ma wartość fałsz -
Pokaż przykład
Sr.No. | Operator i opis |
---|---|
1 | and Nazywany operatorem logicznym AND. Jeśli oba operandy są prawdziwe, wtedy warunek staje się prawdziwy. Example - ($ a i $ b) jest fałszem. |
2 | && Operator logiczny AND w stylu C kopiuje bit do wyniku, jeśli istnieje w obu operandach. Example - ($ a && $ b) jest fałszem. |
3 | or Nazywany operatorem logicznym OR. Jeśli którykolwiek z dwóch operandów jest niezerowy, wtedy warunek staje się prawdziwy. Example - ($ a lub $ b) jest prawdą. |
4 | || Operator logiczny OR w stylu C kopiuje bit, jeśli istnieje w operandzie. Example - ($ a || $ b) jest prawdą. |
5 | not Nazywany operatorem logicznym NOT. Służy do odwracania stanu logicznego operandu. Jeśli warunek jest spełniony, operator logiczny NOT spowoduje fałsz. Example - not ($ a i $ b) jest prawdą. |
Operatory podobne do kwotowań
Istnieją następujące operatory podobne do cytatów, obsługiwane przez język Perl. W poniższej tabeli {} oznacza dowolną wybraną parę separatorów.
Pokaż przykład
Sr.No. | Operator i opis |
---|---|
1 | q{ } Obejmuje ciąg w apostrofach Example - q {abcd} daje „abcd” |
2 | qq{ } Obejmuje ciąg w podwójnych cudzysłowach Example - qq {abcd} daje „abcd” |
3 | qx{ } Obejmuje ciąg w cudzysłów odwrócony Example - qx {abcd} daje „abcd” |
Różni operatorzy
Istnieją różne operatory obsługiwane przez język Perl. Załóżmy, że zmienna a zawiera 10, a zmienna b 20, a następnie
Pokaż przykład
Sr.No. | Operator i opis |
---|---|
1 | . Operator binarny kropka (.) Łączy dwa ciągi. Example - Jeśli $ a = "abc", $b = "def" then $a. $ b da "abcdef" |
2 | x Operator powtórzenia x zwraca ciąg składający się z lewego operandu powtórzonego tyle razy, ile określono przez prawy operand. Example - ('-' x 3) da ---. |
3 | .. Operator zakresu .. zwraca listę wartości zliczanych (w górę o jedności) od lewej do prawej wartości Example - (2..5) da (2, 3, 4, 5) |
4 | ++ Operator Auto Increment zwiększa wartość całkowitą o jeden Example - $ a ++ da 11 |
5 | -- Operator Auto Decrement zmniejsza wartość całkowitą o jeden Example - $ a-- daje 9 |
6 | -> Operator strzałki jest najczęściej używany do wyłuskiwania metody lub zmiennej z obiektu lub nazwy klasy Example - $ obj->$a is an example to access variable $a z obiektu $ obj. |
Pierwszeństwo operatorów Perla
W poniższej tabeli wymieniono wszystkie operatory od najwyższego do najniższego priorytetu.
Pokaż przykład
left terms and list operators (leftward)
left ->
nonassoc ++ --
right **
right ! ~ \ and unary + and -
left =~ !~
left * / % x
left + - .
left << >>
nonassoc named unary operators
nonassoc < > <= >= lt gt le ge
nonassoc == != <=> eq ne cmp ~~
left &
left | ^
left &&
left || //
nonassoc .. ...
right ?:
right = += -= *= etc.
left , =>
nonassoc list operators (rightward)
right not
left and
left or xor
W tym rozdziale dowiesz się, jak przetwarzać i manipulować datami i godzinami w Perlu.
Bieżąca data i godzina
Zacznijmy localtime()funkcja, która zwraca wartości dla bieżącej daty i godziny, jeśli nie podano żadnych argumentów. Poniżej znajduje się lista 9-elementowa zwrócona przezlocaltime funkcja podczas używania w kontekście listowym -
sec, # seconds of minutes from 0 to 61
min, # minutes of hour from 0 to 59
hour, # hours of day from 0 to 24
mday, # day of month from 1 to 31
mon, # month of year from 0 to 11
year, # year since 1900
wday, # days since sunday
yday, # days since January 1st
isdst # hours of daylight savings time
Wypróbuj poniższy przykład, aby wydrukować różne elementy zwrócone przez funkcję localtime () -
#!/usr/local/bin/perl
@months = qw( Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec );
@days = qw(Sun Mon Tue Wed Thu Fri Sat Sun);
($sec,$min,$hour,$mday,$mon,$year,$wday,$yday,$isdst) = localtime();
print "$mday $months[$mon] $days[$wday]\n";
Wykonanie powyższego kodu daje następujący wynik -
16 Feb Sat
Jeśli będziesz używać funkcji localtime () w kontekście skalarnym, zwróci ona datę i czas z bieżącej strefy czasowej ustawionej w systemie. Wypróbuj poniższy przykład, aby wydrukować bieżącą datę i godzinę w pełnym formacie -
#!/usr/local/bin/perl
$datestring = localtime();
print "Local date and time $datestring\n";
Wykonanie powyższego kodu daje następujący wynik -
Local date and time Sat Feb 16 06:50:45 2013
Czas GMT
Funkcja gmtime()działa tak samo jak funkcja localtime (), ale zwracane wartości są zlokalizowane dla standardowej strefy czasowej Greenwich. Gdy wywoływana jest w kontekście listowym, $ isdst, ostatnia wartość zwrócona przez gmtime, zawsze wynosi 0. W GMT nie ma czasu letniego.
Należy zwrócić uwagę na fakt, że localtime () zwróci bieżący czas lokalny na maszynie, na której jest uruchomiony skrypt, a funkcja gmtime () zwróci uniwersalny czas Greenwich, czyli GMT (lub UTC).
Wypróbuj poniższy przykład, aby wydrukować bieżącą datę i godzinę, ale w skali GMT -
#!/usr/local/bin/perl
$datestring = gmtime(); print "GMT date and time $datestring\n";
Wykonanie powyższego kodu daje następujący wynik -
GMT date and time Sat Feb 16 13:50:45 2013
Formatuj datę i godzinę
Możesz użyć funkcji localtime (), aby uzyskać listę 9 elementów, a później możesz użyć printf() funkcja formatowania daty i godziny w oparciu o Twoje wymagania w następujący sposób -
#!/usr/local/bin/perl
($sec,$min,$hour,$mday,$mon,$year,$wday,$yday,$isdst) = localtime(); printf("Time Format - HH:MM:SS\n"); printf("%02d:%02d:%02d", $hour, $min, $sec);
Wykonanie powyższego kodu daje następujący wynik -
Time Format - HH:MM:SS
06:58:52
Czas epoki
Możesz użyć funkcji time (), aby uzyskać czas epoki, tj. Liczbę sekund, które upłynęły od określonej daty, w systemie Unix to 1 stycznia 1970.
#!/usr/local/bin/perl
$epoc = time(); print "Number of seconds since Jan 1, 1970 - $epoc\n";
Wykonanie powyższego kodu daje następujący wynik -
Number of seconds since Jan 1, 1970 - 1361022130
Możesz przekonwertować określoną liczbę sekund na ciąg daty i czasu w następujący sposób -
#!/usr/local/bin/perl
$datestring = localtime(); print "Current date and time $datestring\n";
$epoc = time(); $epoc = $epoc - 24 * 60 * 60; # one day before of current date. $datestring = localtime($epoc); print "Yesterday's date and time $datestring\n";
Wykonanie powyższego kodu daje następujący wynik -
Current date and time Tue Jun 5 05:54:43 2018
Yesterday's date and time Mon Jun 4 05:54:43 2018
Funkcja POSIX strftime ()
Możesz użyć funkcji POSIX strftime()aby sformatować datę i godzinę za pomocą poniższej tabeli. Należy pamiętać, że specyfikatory oznaczone gwiazdką (*) zależą od ustawień regionalnych.
Specyficzny | Zastąpiony przez | Przykład |
---|---|---|
%a |
Skrócona nazwa dnia tygodnia * | Thu |
%A |
Pełna nazwa dnia tygodnia * | Thursday |
%b |
Skrócona nazwa miesiąca * | Aug |
%B |
Pełna nazwa miesiąca * | August |
%c |
Przedstawienie daty i czasu * | Thu Aug 23 14:55:02 2001 |
%C |
Rok podzielony przez 100 i obcięty do liczby całkowitej ( 00-99 ) |
20 |
%d |
Dzień miesiąca, wypełniony zerami ( 01-31 ) |
23 |
%D |
Krótka MM/DD/YY data, odpowiednik%m/%d/%y |
08/23/01 |
%e |
Dzień miesiąca, wypełniony spacjami ( 1-31 ) |
23 |
%F |
Krótka YYYY-MM-DD data, odpowiednik%Y-%m-%d |
2001-08-23 |
%g |
Rok tygodniowy, ostatnie dwie cyfry ( 00-99 ) |
01 |
%G |
Rok tygodniowy | 2001 |
%h |
Skrócona nazwa miesiąca * (taka sama jak %b ) |
Aug |
%H |
Godzina w formacie 24h ( 00-23 ) |
14 |
%I |
Godzina w formacie 12-godzinnym ( 01-12 ) |
02 |
%j |
Dzień roku ( 001-366 ) |
235 |
%m |
Miesiąc jako liczba dziesiętna ( 01-12 ) |
08 |
%M |
Minuta ( 00-59 ) |
55 |
%n |
Znak nowego wiersza ( '\n' ) |
|
%p |
Oznaczenie AM lub PM | PM |
%r |
12-godzinny zegar * | 02:55:02 pm |
%R |
Czas 24-godzinny HH:MM , odpowiednik%H:%M |
14:55 |
%S |
Drugi ( 00-61 ) |
02 |
%t |
Znak tabulacji poziomej ( '\t' ) |
|
%T |
Format czasu ISO 8601 ( HH:MM:SS ), odpowiednik%H:%M:%S |
14:55 |
%u |
Dzień tygodnia ISO 8601 jako liczba z poniedziałkiem jako 1 ( 1-7 ) |
4 |
%U |
Numer tygodnia z pierwszą niedzielą jako pierwszym dniem pierwszego tygodnia ( 00-53 ) |
33 |
%V |
Numer tygodnia ISO 8601 ( 00-53 ) |
34 |
%w |
Dzień tygodnia jako liczba dziesiętna z niedzielą jako 0 ( 0-6 ) |
4 |
%W |
Numer tygodnia z pierwszym poniedziałkiem jako pierwszym dniem pierwszego tygodnia ( 00-53 ) |
34 |
%x |
Przedstawienie daty * | 08/23/01 |
%X |
Reprezentacja czasu * | 14:55:02 |
%y |
Rok, ostatnie dwie cyfry ( 00-99 ) |
01 |
%Y |
Rok | 2001 |
%z |
Przesunięcie ISO 8601 względem UTC w strefie czasowej (1 minuta = 1, 1 godzina = 100) Jeśli nie można określić strefy czasowej, żadnych znaków |
+100 |
%Z |
Nazwa lub skrót strefy czasowej * Jeśli nie można określić strefy czasowej, żadnych znaków |
CDT |
%% |
% znak |
% |
Sprawdźmy następujący przykład, aby zrozumieć użycie -
#!/usr/local/bin/perl
use POSIX qw(strftime);
$datestring = strftime "%a %b %e %H:%M:%S %Y", localtime; printf("date and time - $datestring\n");
# or for GMT formatted appropriately for your locale:
$datestring = strftime "%a %b %e %H:%M:%S %Y", gmtime; printf("date and time - $datestring\n");
Wykonanie powyższego kodu daje następujący wynik -
date and time - Sat Feb 16 07:10:23 2013
date and time - Sat Feb 16 14:10:23 2013
Podprogram lub funkcja Perla to grupa instrukcji, które razem wykonują zadanie. Możesz podzielić swój kod na oddzielne podprogramy. To, jak podzielisz swój kod na różne podprogramy, zależy od Ciebie, ale logicznie jest to zazwyczaj taki podział, że każda funkcja wykonuje określone zadanie.
Perl używa zamiennie terminów podprogram, metoda i funkcja.
Zdefiniuj i wywołaj podprogram
Ogólna postać definicji podprogramu w języku programowania Perl jest następująca -
sub subroutine_name {
body of the subroutine
}
Typowy sposób wywołania tego podprogramu Perl jest następujący:
subroutine_name( list of arguments );
W wersjach Perla wcześniejszych niż 5.0, składnia wywoływania podprogramów była nieco inna, jak pokazano poniżej. To nadal działa w najnowszych wersjach Perla, ale nie jest zalecane, ponieważ omija prototypy podprogramów.
&subroutine_name( list of arguments );
Spójrzmy na poniższy przykład, który definiuje prostą funkcję, a następnie ją wywołaj. Ponieważ Perl kompiluje program przed jego wykonaniem, nie ma znaczenia, gdzie zadeklarujesz swój podprogram.
#!/usr/bin/perl
# Function definition
sub Hello {
print "Hello, World!\n";
}
# Function call
Hello();
Wykonanie powyższego programu daje następujący wynik -
Hello, World!
Przekazywanie argumentów do podprogramu
Możesz przekazać różne argumenty do podprogramu, tak jak robisz to w każdym innym języku programowania i można je uzyskać wewnątrz funkcji za pomocą specjalnej tablicy @_. Zatem pierwszy argument funkcji znajduje się w$_[0], the second is in $_ [1] i tak dalej.
Możesz przekazywać tablice i skróty jako argumenty jak każdy skalar, ale przekazanie więcej niż jednej tablicy lub skrótu zwykle powoduje utratę oddzielnych tożsamości. Dlatego użyjemy referencji (wyjaśnionych w następnym rozdziale) do przekazania dowolnej tablicy lub skrótu.
Wypróbujmy następujący przykład, który pobiera listę liczb, a następnie wyświetla ich średnią -
#!/usr/bin/perl
# Function definition
sub Average {
# get total number of arguments passed.
$n = scalar(@_); $sum = 0;
foreach $item (@_) { $sum += $item; } $average = $sum / $n;
print "Average for the given numbers : $average\n";
}
# Function call
Average(10, 20, 30);
Wykonanie powyższego programu daje następujący wynik -
Average for the given numbers : 20
Przekazywanie list do podprogramów
Ponieważ zmienna @_ jest tablicą, może służyć do dostarczania list do podprogramu. Jednak ze względu na sposób, w jaki Perl akceptuje i analizuje listy i tablice, wyodrębnienie poszczególnych elementów z @_ może być trudne. Jeśli musisz przekazać listę wraz z innymi argumentami skalarnymi, utwórz listę jako ostatni argument, jak pokazano poniżej -
#!/usr/bin/perl
# Function definition
sub PrintList {
my @list = @_;
print "Given list is @list\n";
}
$a = 10;
@b = (1, 2, 3, 4);
# Function call with list parameter
PrintList($a, @b);
Wykonanie powyższego programu daje następujący wynik -
Given list is 10 1 2 3 4
Przekazywanie skrótów do podprogramów
Kiedy podasz hash do podprogramu lub operatora, który akceptuje listę, hash jest automatycznie tłumaczony na listę par klucz / wartość. Na przykład -
#!/usr/bin/perl
# Function definition
sub PrintHash {
my (%hash) = @_;
foreach my $key ( keys %hash ) {
my $value = $hash{$key}; print "$key : $value\n";
}
}
%hash = ('name' => 'Tom', 'age' => 19);
# Function call with hash parameter
PrintHash(%hash);
Wykonanie powyższego programu daje następujący wynik -
name : Tom
age : 19
Zwracanie wartości z podprogramu
Możesz zwrócić wartość z podprogramu, tak jak w każdym innym języku programowania. Jeśli nie zwracasz wartości z podprogramu, wówczas wszelkie obliczenia, które są ostatnio wykonywane w podprogramie, są automatycznie również wartością zwracaną.
Możesz zwracać tablice i skróty z podprogramu jak każdy skalar, ale zwrócenie więcej niż jednej tablicy lub skrótu zwykle powoduje utratę oddzielnych tożsamości. Więc użyjemy referencji (wyjaśnionych w następnym rozdziale) do zwrócenia dowolnej tablicy lub skrótu z funkcji.
Wypróbujmy następujący przykład, który pobiera listę liczb, a następnie zwraca ich średnią -
#!/usr/bin/perl
# Function definition
sub Average {
# get total number of arguments passed.
$n = scalar(@_);
$sum = 0; foreach $item (@_) {
$sum += $item;
}
$average = $sum / $n; return $average;
}
# Function call
$num = Average(10, 20, 30); print "Average for the given numbers : $num\n";
Wykonanie powyższego programu daje następujący wynik -
Average for the given numbers : 20
Zmienne prywatne w podprogramie
Domyślnie wszystkie zmienne w Perlu są zmiennymi globalnymi, co oznacza, że można uzyskać do nich dostęp z dowolnego miejsca w programie. Ale możesz tworzyćprivate zmienne o nazwie lexical variables w dowolnym momencie z my operator.
Plik myoperator ogranicza zmienną do określonego regionu kodu, w którym można jej użyć i uzyskać do niej dostęp. Poza tym regionem nie można użyć tej zmiennej ani uzyskać do niej dostępu. Ten region nazywa się jego zasięgiem. Zakres leksykalny to zwykle blok kodu z zestawem nawiasów wokół niego, na przykład definiujących treść podprogramu lub oznaczających bloki kodu instrukcji if, while, for, foreach i eval .
Poniżej znajduje się przykład pokazujący, jak zdefiniować jedną lub wiele zmiennych prywatnych za pomocą my operator -
sub somefunc {
my $variable; # $variable is invisible outside somefunc()
my ($another, @an_array, %a_hash); # declaring many variables at once
}
Sprawdźmy następujący przykład, aby rozróżnić zmienne globalne i prywatne -
#!/usr/bin/perl
# Global variable
$string = "Hello, World!";
# Function definition
sub PrintHello {
# Private variable for PrintHello function
my $string; $string = "Hello, Perl!";
print "Inside the function $string\n"; } # Function call PrintHello(); print "Outside the function $string\n";
Wykonanie powyższego programu daje następujący wynik -
Inside the function Hello, Perl!
Outside the function Hello, World!
Wartości tymczasowe przez local ()
Plik localjest najczęściej używany, gdy bieżąca wartość zmiennej musi być widoczna dla wywoływanych podprogramów. Lokalny po prostu podaje tymczasowe wartości zmiennym globalnym (co oznacza pakiet). Nazywa się to dynamicznym określaniem zakresu . Zakres leksykalny jest wykonywany za pomocą my, co działa bardziej jak automatyczne deklaracje języka C.
Jeśli parametr local zawiera więcej niż jedną zmienną lub wyrażenie, należy je umieścić w nawiasach. Ten operator działa poprzez zapisywanie bieżących wartości tych zmiennych na liście argumentów na ukrytym stosie i przywracanie ich po wyjściu z bloku, podprogramu lub funkcji eval.
Sprawdźmy następujący przykład, aby rozróżnić zmienne globalne i lokalne -
#!/usr/bin/perl
# Global variable
$string = "Hello, World!"; sub PrintHello { # Private variable for PrintHello function local $string;
$string = "Hello, Perl!"; PrintMe(); print "Inside the function PrintHello $string\n";
}
sub PrintMe {
print "Inside the function PrintMe $string\n"; } # Function call PrintHello(); print "Outside the function $string\n";
Wykonanie powyższego programu daje następujący wynik -
Inside the function PrintMe Hello, Perl!
Inside the function PrintHello Hello, Perl!
Outside the function Hello, World!
Zmienne stanu za pośrednictwem state ()
Istnieje inny typ zmiennych leksykalnych, które są podobne do zmiennych prywatnych, ale zachowują swój stan i nie są ponownie inicjowane po wielokrotnym wywołaniu podprogramów. Te zmienne są definiowane za pomocąstate operator i dostępne począwszy od Perla 5.9.4.
Sprawdźmy następujący przykład, aby zademonstrować użycie state zmienne -
#!/usr/bin/perl
use feature 'state';
sub PrintCount {
state $count = 0; # initial value print "Value of counter is $count\n";
$count++;
}
for (1..5) {
PrintCount();
}
Wykonanie powyższego programu daje następujący wynik -
Value of counter is 0
Value of counter is 1
Value of counter is 2
Value of counter is 3
Value of counter is 4
Przed Perl 5.10 musiałbyś napisać to w ten sposób -
#!/usr/bin/perl
{
my $count = 0; # initial value
sub PrintCount {
print "Value of counter is $count\n"; $count++;
}
}
for (1..5) {
PrintCount();
}
Kontekst wywołania podprogramu
Kontekst podprogramu lub instrukcji jest definiowany jako typ oczekiwanej wartości zwracanej. Pozwala to na użycie jednej funkcji, która zwraca różne wartości w zależności od tego, czego oczekuje użytkownik. Na przykład poniższa funkcja localtime () zwraca ciąg, gdy jest wywoływana w kontekście skalarnym, ale zwraca listę, gdy jest wywoływana w kontekście listowym.
my $datestring = localtime( time );
W tym przykładzie wartość $ timestr jest teraz ciągiem znaków składającym się z bieżącej daty i godziny, na przykład Thu 30 Nov 15:21:33 2000. I odwrotnie -
($sec,$min,$hour,$mday,$mon, $year,$wday,$yday,$isdst) = localtime(time);
Teraz poszczególne zmienne zawierają odpowiadające im wartości zwracane przez podprogram localtime ().
Odwołanie do Perla to skalarny typ danych, który przechowuje lokalizację innej wartości, która może być skalarna, tablice lub skróty. Ze względu na swój skalarny charakter odniesienie może być używane w dowolnym miejscu, można również użyć skalara.
Możesz tworzyć listy zawierające odwołania do innych list, które mogą zawierać odwołania do skrótów i tak dalej. Tak buduje się zagnieżdżone struktury danych w Perlu.
Utwórz odniesienia
Łatwo jest utworzyć odniesienie do dowolnej zmiennej, podprogramu lub wartości, poprzedzając je odwrotnym ukośnikiem w następujący sposób -
$scalarref = \$foo; $arrayref = \@ARGV;
$hashref = \%ENV; $coderef = \&handler;
$globref = \*foo;
Nie można utworzyć odwołania do uchwytu wejścia / wyjścia (uchwytu pliku lub uchwytu) za pomocą operatora ukośnika odwrotnego, ale odwołanie do tablicy anonimowej można utworzyć za pomocą nawiasów kwadratowych w następujący sposób -
$arrayref = [1, 2, ['a', 'b', 'c']];
W podobny sposób możesz utworzyć odniesienie do anonimowego skrótu za pomocą nawiasów klamrowych w następujący sposób -
$hashref = {
'Adam' => 'Eve',
'Clyde' => 'Bonnie',
};
Odwołanie do anonimowego podprogramu można utworzyć za pomocą podprogramu bez nazwy podrzędnej w następujący sposób -
$coderef = sub { print "Boink!\n" };
Dereferencing
Dereferencing zwraca wartość z punktu odniesienia do lokalizacji. Aby wyłuskać odwołanie, po prostu użyj $, @ lub% jako przedrostka zmiennej referencyjnej w zależności od tego, czy odwołanie wskazuje na wartość skalarną, tablicę czy hash. Poniżej znajduje się przykład wyjaśniający koncepcję -
#!/usr/bin/perl
$var = 10;
# Now $r has reference to $var scalar.
$r = \$var;
# Print value available at the location stored in $r. print "Value of $var is : ", $$r, "\n"; @var = (1, 2, 3); # Now $r has reference to @var array.
$r = \@var; # Print values available at the location stored in $r.
print "Value of @var is : ", @$r, "\n"; %var = ('key1' => 10, 'key2' => 20); # Now $r has reference to %var hash.
$r = \%var; # Print values available at the location stored in $r.
print "Value of %var is : ", %$r, "\n";
Wykonanie powyższego programu daje następujący wynik -
Value of 10 is : 10
Value of 1 2 3 is : 123
Value of %var is : key220key110
Jeśli nie masz pewności co do typu zmiennej, możesz łatwo poznać jej typ za pomocą ref, która zwraca jeden z następujących ciągów, jeśli jego argument jest odwołaniem. W przeciwnym razie zwraca false -
SCALAR
ARRAY
HASH
CODE
GLOB
REF
Wypróbujmy następujący przykład -
#!/usr/bin/perl
$var = 10;
$r = \$var;
print "Reference type in r : ", ref($r), "\n"; @var = (1, 2, 3); $r = \@var;
print "Reference type in r : ", ref($r), "\n"; %var = ('key1' => 10, 'key2' => 20); $r = \%var;
print "Reference type in r : ", ref($r), "\n";
Wykonanie powyższego programu daje następujący wynik -
Reference type in r : SCALAR
Reference type in r : ARRAY
Reference type in r : HASH
Odnośniki cykliczne
Odwołanie cykliczne występuje, gdy dwa odwołania zawierają odwołanie do siebie. Podczas tworzenia referencji należy zachować ostrożność, w przeciwnym razie odwołanie cykliczne może prowadzić do wycieków pamięci. Oto przykład -
#!/usr/bin/perl
my $foo = 100;
$foo = \$foo;
print "Value of foo is : ", $$foo, "\n";
Wykonanie powyższego programu daje następujący wynik -
Value of foo is : REF(0x9aae38)
Odniesienia do funkcji
Może się tak zdarzyć, jeśli chcesz utworzyć procedurę obsługi sygnału, aby móc utworzyć odwołanie do funkcji, poprzedzając tę nazwę funkcji za pomocą \ &, a aby usunąć odwołanie, wystarczy poprzedzić zmienną odniesienia za pomocą znaku &. Oto przykład -
#!/usr/bin/perl
# Function definition
sub PrintHash {
my (%hash) = @_;
foreach $item (%hash) {
print "Item : $item\n"; } } %hash = ('name' => 'Tom', 'age' => 19); # Create a reference to above function. $cref = \&PrintHash;
# Function call using reference.
&$cref(%hash);
Wykonanie powyższego programu daje następujący wynik -
Item : name
Item : Tom
Item : age
Item : 19
Perl używa szablonu do pisania zwanego „formatem” do tworzenia raportów. Aby użyć funkcji formatowania Perla, musisz najpierw zdefiniować format, a następnie możesz użyć tego formatu do zapisania sformatowanych danych.
Zdefiniuj format
Poniżej znajduje się składnia definiująca format Perla -
format FormatName =
fieldline
value_one, value_two, value_three
fieldline
value_one, value_two
.
Tutaj FormatNamereprezentuje nazwę formatu. Plikfieldlinejest specyficzny sposób, w jaki dane powinny być sformatowane. Linie wartości reprezentują wartości, które zostaną wprowadzone w wierszu pola. Kończysz format pojedynczą kropką.
Kolejny fieldlinemoże zawierać dowolny tekst lub symbole pól. W polach jest miejsce na dane, które zostaną tam umieszczone w późniejszym terminie. Symbol pola ma format -
@<<<<
Ten symbol pola jest wyrównany do lewej, z miejscem na pole równym 5. Musisz policzyć znak @ i <, aby poznać liczbę spacji w polu. Inni posiadacze pola to -
@>>>> right-justified
@|||| centered
@####.## numeric field holder
@* multiline field holder
Przykładowy format to -
format EMPLOYEE =
===================================
@<<<<<<<<<<<<<<<<<<<<<< @<<
$name $age @#####.## $salary
===================================
.
W tym przykładzie $ name zostanie zapisane jako justowanie do lewej w obrębie 22 znaków, a po tym wieku zostanie zapisane w dwóch spacjach.
Korzystanie z formatu
Aby wywołać tę deklarację formatu, użylibyśmy rozszerzenia write słowo kluczowe -
write EMPLOYEE;
Problem polega na tym, że nazwa formatu jest zwykle nazwą otwartego uchwytu pliku, a instrukcja write wyśle dane wyjściowe do tego uchwytu pliku. Ponieważ chcemy, aby dane były wysyłane do STDOUT, musimy skojarzyć PRACOWNIKA z uchwytem pliku STDOUT. Najpierw jednak musimy upewnić się, że STDOUT jest naszym wybranym uchwytem pliku, używając funkcji select ().
select(STDOUT);
Następnie skojarzymy PRACOWNIKA ze STDOUT, ustawiając nową nazwę formatu za pomocą STDOUT, używając specjalnej zmiennej $ ~ lub $ FORMAT_NAME w następujący sposób -
$~ = "EMPLOYEE";
Kiedy teraz wykonamy write (), dane zostaną wysłane do STDOUT. Pamiętaj: jeśli zamierzasz zapisać swój raport w jakimkolwiek innym uchwycie pliku zamiast w STDOUT, możesz użyć funkcji select (), aby wybrać ten uchwyt, a reszta logiki pozostanie taka sama.
Weźmy następujący przykład. Tutaj mamy zakodowane wartości tylko do pokazania użycia. Podczas rzeczywistego użytkowania będziesz odczytywał wartości z pliku lub bazy danych w celu wygenerowania rzeczywistych raportów i może być konieczne ponowne zapisanie raportu końcowego do pliku.
#!/usr/bin/perl
format EMPLOYEE =
===================================
@<<<<<<<<<<<<<<<<<<<<<< @<<
$name $age
@#####.##
$salary =================================== . select(STDOUT); $~ = EMPLOYEE;
@n = ("Ali", "Raza", "Jaffer");
@a = (20,30, 40);
@s = (2000.00, 2500.00, 4000.000);
$i = 0; foreach (@n) { $name = $_; $age = $a[$i];
$salary = $s[$i++];
write;
}
Po uruchomieniu da to następujący wynik -
===================================
Ali 20
2000.00
===================================
===================================
Raza 30
2500.00
===================================
===================================
Jaffer 40
4000.00
===================================
Zdefiniuj nagłówek raportu
Wszystko wygląda dobrze. Ale byłbyś zainteresowany dodaniem nagłówka do raportu. Ten nagłówek zostanie wydrukowany na górze każdej strony. Jest to bardzo proste. Oprócz zdefiniowania szablonu należałoby zdefiniować nagłówek i przypisać go do zmiennej $ ^ lub $ FORMAT_TOP_NAME -
#!/usr/bin/perl
format EMPLOYEE =
===================================
@<<<<<<<<<<<<<<<<<<<<<< @<<
$name $age @#####.## $salary
===================================
.
format EMPLOYEE_TOP =
===================================
Name Age
===================================
.
select(STDOUT);
$~ = EMPLOYEE; $^ = EMPLOYEE_TOP;
@n = ("Ali", "Raza", "Jaffer");
@a = (20,30, 40);
@s = (2000.00, 2500.00, 4000.000);
$i = 0; foreach (@n) { $name = $_; $age = $a[$i];
$salary = $s[$i++];
write;
}
Teraz Twój raport będzie wyglądał następująco -
===================================
Name Age
===================================
===================================
Ali 20
2000.00
===================================
===================================
Raza 30
2500.00
===================================
===================================
Jaffer 40
4000.00
===================================
Zdefiniuj paginację
A co jeśli raport zajmuje więcej niż jedną stronę? Masz na to rozwiązanie, po prostu użyj$% lub $ FORMAT_PAGE_NUMBER vairable wraz z nagłówkiem w następujący sposób -
format EMPLOYEE_TOP =
===================================
Name Age Page @<
$%
===================================
.
Teraz wynik będzie wyglądał następująco -
===================================
Name Age Page 1
===================================
===================================
Ali 20
2000.00
===================================
===================================
Raza 30
2500.00
===================================
===================================
Jaffer 40
4000.00
===================================
Liczba wierszy na stronie
Możesz ustawić liczbę wierszy na stronę za pomocą specjalnej zmiennej $= (lub $ FORMAT_LINES_PER_PAGE), Domyślnie $ = będzie wynosić 60.
Zdefiniuj stopkę raportu
Podczas gdy $ ^ lub $FORMAT_TOP_NAME contains the name of the current header format, there is no corresponding mechanism to automatically do the same thing for a footer. If you have a fixed-size footer, you can get footers by checking variable $- lub $ FORMAT_LINES_LEFT przed każdym write () i samodzielnie wydrukuj stopkę, jeśli to konieczne, używając innego formatu zdefiniowanego w następujący sposób -
format EMPLOYEE_BOTTOM =
End of Page @<
$%
.
Aby uzyskać pełny zestaw zmiennych związanych z formatowaniem, zapoznaj się z sekcją Zmienne specjalne Perla .
Podstawy obsługi plików są proste: kojarzysz plik filehandle z jednostką zewnętrzną (zwykle plikiem), a następnie użyj różnych operatorów i funkcji w Perlu, aby odczytać i zaktualizować dane przechowywane w strumieniu danych skojarzonym z uchwytem pliku.
Uchwyt pliku to nazwana wewnętrzna struktura Perla, która wiąże fizyczny zbiór z nazwą. Wszystkie uchwyty plików mają dostęp do odczytu / zapisu, dzięki czemu można odczytywać i aktualizować dowolny plik lub urządzenie powiązane z uchwytem pliku. Jednak podczas kojarzenia uchwytu pliku można określić tryb, w którym uchwyt pliku jest otwierany.
Trzy podstawowe uchwyty plików to - STDIN, STDOUT, i STDERR, które reprezentują odpowiednio standardowe wejście, standardowe wyjście i standardowe urządzenia błędów.
Otwieranie i zamykanie plików
Istnieją dwie funkcje z wieloma formularzami, których można użyć do otwarcia dowolnego nowego lub istniejącego pliku w Perlu.
open FILEHANDLE, EXPR
open FILEHANDLE
sysopen FILEHANDLE, FILENAME, MODE, PERMS
sysopen FILEHANDLE, FILENAME, MODE
W tym przypadku UCHWYT PLIKU jest uchwytem pliku zwróconym przez open funkcja, a WYRAŻ jest wyrażeniem mającym nazwę pliku i tryb otwierania pliku.
Otwórz funkcję
Poniżej znajduje się składnia do otwarcia file.txtw trybie tylko do odczytu. Tutaj mniej niż znak <wskazuje, że plik musi być otwarty w trybie tylko do odczytu.
open(DATA, "<file.txt");
Tutaj DANE to uchwyt pliku, który zostanie użyty do odczytania pliku. Oto przykład, który otworzy plik i wydrukuje jego zawartość na ekranie.
#!/usr/bin/perl
open(DATA, "<file.txt") or die "Couldn't open file file.txt, $!"; while(<DATA>) { print "$_";
}
Poniżej przedstawiono składnię otwierania pliku file.txt w trybie pisania. Tutaj znak mniejszy niż> wskazuje, że plik musi być otwarty w trybie zapisu.
open(DATA, ">file.txt") or die "Couldn't open file file.txt, $!";
Ten przykład w rzeczywistości obcina (opróżnia) plik przed otwarciem go do zapisu, co może nie być pożądanym efektem. Jeśli chcesz otworzyć plik do czytania i pisania, możesz umieścić znak plus przed znakami> lub <.
Na przykład, aby otworzyć plik do aktualizacji bez obcinania go -
open(DATA, "+<file.txt"); or die "Couldn't open file file.txt, $!";
Aby najpierw obciąć plik -
open DATA, "+>file.txt" or die "Couldn't open file file.txt, $!";
Możesz otworzyć plik w trybie dołączania. W tym trybie punkt zapisu zostanie ustawiony na końcu pliku.
open(DATA,">>file.txt") || die "Couldn't open file file.txt, $!";
Podwójne >> otwiera plik do dołączenia, umieszczając wskaźnik pliku na końcu, dzięki czemu można natychmiast rozpocząć dołączanie informacji. Jednak nie możesz z niego czytać, chyba że umieścisz przed nim również znak plus -
open(DATA,"+>>file.txt") || die "Couldn't open file file.txt, $!";
Poniżej znajduje się tabela, w której podano możliwe wartości różnych trybów
Sr.No. | Podmioty i definicja |
---|---|
1 | < or r Dostęp tylko do odczytu |
2 | > or w Tworzy, zapisuje i obcina |
3 | >> or a Pisze, dołącza i tworzy |
4 | +< or r+ Czyta i pisze |
5 | +> or w+ Czyta, pisze, tworzy i obcina |
6 | +>> or a+ Czyta, zapisuje, dołącza i tworzy |
Funkcja Sysopen
Plik sysopen funkcja jest podobna do głównej funkcji otwartej, z tym wyjątkiem, że wykorzystuje system open() funkcji, wykorzystując podane parametry jako parametry funkcji systemowej -
Na przykład, aby otworzyć plik do aktualizacji, emuluj rozszerzenie +<filename format od otwarcia -
sysopen(DATA, "file.txt", O_RDWR);
Lub skrócić plik przed aktualizacją -
sysopen(DATA, "file.txt", O_RDWR|O_TRUNC );
Możesz użyć O_CREAT do utworzenia nowego pliku i O_WRONLY- do otwarcia pliku w trybie tylko do zapisu i O_RDONLY - do otwarcia pliku w trybie tylko do odczytu.
Plik PERMSargument określa uprawnienia do określonego pliku, jeśli ma zostać utworzony. Domyślnie trwa0x666.
Poniżej znajduje się tabela, która zawiera możliwe wartości TRYBU.
Sr.No. | Podmioty i definicja |
---|---|
1 | O_RDWR Czytaj i pisz |
2 | O_RDONLY Tylko czytać |
3 | O_WRONLY Tylko pisz |
4 | O_CREAT Utwórz plik |
5 | O_APPEND Dołącz plik |
6 | O_TRUNC Obetnij plik |
7 | O_EXCL Zatrzymuje się, jeśli plik już istnieje |
8 | O_NONBLOCK Nieblokująca użyteczność |
Zamknij funkcję
Aby zamknąć uchwyt pliku, a tym samym odłączyć uchwyt pliku od odpowiedniego pliku, użyj rozszerzenia closefunkcjonować. To opróżnia bufory uchwytu pliku i zamyka deskryptor pliku systemowego.
close FILEHANDLE
close
Jeśli nie określono elementu FILEHANDLE, zamyka on aktualnie wybrany uchwyt pliku. Zwraca prawdę tylko wtedy, gdy może pomyślnie opróżnić bufory i zamknąć plik.
close(DATA) || die "Couldn't close file properly";
Czytanie i pisanie plików
Gdy masz otwarty uchwyt pliku, musisz umieć czytać i zapisywać informacje. Istnieje wiele różnych sposobów odczytywania i zapisywania danych w pliku.
Operator <FILEHANDL>
Główną metodą odczytu informacji z otwartego uchwytu pliku jest operator <FILEHANDLE>. W kontekście skalarnym zwraca pojedynczą linię z uchwytu pliku. Na przykład -
#!/usr/bin/perl
print "What is your name?\n";
$name = <STDIN>;
print "Hello $name\n";
Kiedy używasz operatora <FILEHANDLE> w kontekście listowym, zwraca on listę wierszy z określonego uchwytu pliku. Na przykład, aby zaimportować wszystkie wiersze z pliku do tablicy -
#!/usr/bin/perl
open(DATA,"<import.txt") or die "Can't open data";
@lines = <DATA>;
close(DATA);
Funkcja getc
Funkcja getc zwraca pojedynczy znak z podanego UCHWYTU PLIKU lub STDIN, jeśli żaden nie został określony -
getc FILEHANDLE
getc
Jeśli wystąpił błąd lub uchwyt pliku znajduje się na końcu pliku, zamiast tego zwracany jest undef.
Przeczytaj funkcję
Funkcja odczytu odczytuje blok informacji z buforowanego uchwytu pliku: Ta funkcja służy do odczytu danych binarnych z pliku.
read FILEHANDLE, SCALAR, LENGTH, OFFSET
read FILEHANDLE, SCALAR, LENGTH
Długość odczytywanych danych jest definiowana przez LENGTH, a dane są umieszczane na początku SCALARA, jeśli nie określono OFFSET. W przeciwnym razie dane są umieszczane po bajtach OFFSET w SCALAR. Funkcja zwraca liczbę bajtów odczytanych po pomyślnym zakończeniu, zero na końcu pliku lub undef, jeśli wystąpił błąd.
funkcja drukowania
Dla wszystkich metod używanych do odczytywania informacji z uchwytów plików, główną funkcją zapisywania informacji z powrotem jest funkcja drukowania.
print FILEHANDLE LIST
print LIST
print
Funkcja drukowania wypisuje oszacowaną wartość LISTA do UCHWYTU PLIKU lub do bieżącego uchwytu pliku wyjściowego (domyślnie STDOUT). Na przykład -
print "Hello World!\n";
Kopiowanie plików
Oto przykład, który otwiera istniejący plik plik1.txt i odczytuje go wiersz po wierszu i generuje kolejną kopię pliku plik2.txt.
#!/usr/bin/perl
# Open file to read
open(DATA1, "<file1.txt");
# Open new file to write
open(DATA2, ">file2.txt");
# Copy data from one file to another.
while(<DATA1>) {
print DATA2 $_;
}
close( DATA1 );
close( DATA2 );
Zmiana nazwy pliku
Oto przykład, który pokazuje, jak możemy zmienić nazwę pliku file1.txt na file2.txt. Zakładając, że plik jest dostępny w katalogu / usr / test.
#!/usr/bin/perl
rename ("/usr/test/file1.txt", "/usr/test/file2.txt" );
Ta funkcja renames przyjmuje dwa argumenty i po prostu zmienia nazwę istniejącego pliku.
Usuwanie istniejącego pliku
Oto przykład, który pokazuje, jak usunąć plik file1.txt przy użyciu rozszerzenia unlink funkcjonować.
#!/usr/bin/perl
unlink ("/usr/test/file1.txt");
Pozycjonowanie wewnątrz pliku
Możesz użyć do tell funkcja, aby poznać bieżącą pozycję pliku i seek funkcji, aby wskazać określoną pozycję w pliku.
powiedz funkcji
Pierwszym wymaganiem jest znalezienie swojej pozycji w pliku, co robisz za pomocą funkcji tell -
tell FILEHANDLE
tell
Zwraca pozycję wskaźnika pliku, w bajtach, wewnątrz UCHWYTU PLIKU, jeśli jest określony, lub bieżącego domyślnego wybranego uchwytu pliku, jeśli żaden nie jest określony.
funkcja wyszukiwania
Funkcja wyszukiwania ustawia wskaźnik pliku na określoną liczbę bajtów w pliku -
seek FILEHANDLE, POSITION, WHENCE
Funkcja korzysta z funkcji systemowej fseek i masz taką samą możliwość pozycjonowania względem trzech różnych punktów: początku, końca i bieżącej pozycji. Robisz to, określając wartość WHENCE.
Zero ustawia położenie względem początku pliku. Na przykład wiersz ustawia wskaźnik pliku na 256 bajt w pliku.
seek DATA, 256, 0;
Informacje o pliku
Możesz bardzo szybko przetestować pewne funkcje w Perlu, używając szeregu operatorów testów znanych łącznie jako testy -X. Na przykład, aby wykonać szybki test różnych uprawnień do pliku, możesz użyć takiego skryptu -
#/usr/bin/perl
my $file = "/usr/test/file1.txt"; my (@description, $size);
if (-e $file) { push @description, 'binary' if (-B _); push @description, 'a socket' if (-S _); push @description, 'a text file' if (-T _); push @description, 'a block special file' if (-b _); push @description, 'a character special file' if (-c _); push @description, 'a directory' if (-d _); push @description, 'executable' if (-x _); push @description, (($size = -s _)) ? "$size bytes" : 'empty'; print "$file is ", join(', ',@description),"\n";
}
Oto lista funkcji, które możesz sprawdzić pod kątem pliku lub katalogu -
Sr.No. | Operator i definicja |
---|---|
1 | -A Czas rozpoczęcia skryptu minus czas ostatniego dostępu do pliku w dniach. |
2 | -B Czy to plik binarny? |
3 | -C Czas rozpoczęcia skryptu minus czas ostatniej zmiany i-węzła pliku w dniach. |
3 | -M Czas rozpoczęcia skryptu minus czas modyfikacji pliku, w dniach. |
4 | -O Czy właścicielem pliku jest rzeczywisty identyfikator użytkownika? |
5 | -R Czy plik można odczytać za pomocą rzeczywistego identyfikatora użytkownika lub prawdziwej grupy? |
6 | -S Czy plik jest gniazdem? |
7 | -T Czy to plik tekstowy? |
8 | -W Czy plik jest zapisywalny przez rzeczywisty identyfikator użytkownika lub prawdziwą grupę? |
9 | -X Czy plik jest wykonywany przez rzeczywisty identyfikator użytkownika lub prawdziwą grupę? |
10 | -b Czy jest to specjalny plik blokowy? |
11 | -c Czy jest to specjalny plik znaków? |
12 | -d Czy plik jest katalogiem? |
13 | -e Czy plik istnieje? |
14 | -f Czy to zwykły plik? |
15 | -g Czy plik ma ustawiony bit setgid? |
16 | -k Czy plik ma ustawiony bit lepki? |
17 | -l Czy plik jest dowiązaniem symbolicznym? |
18 | -o Czy właścicielem pliku jest efektywny identyfikator użytkownika? |
19 | -p Czy plik jest potokiem nazwanym? |
20 | -r Czy plik jest czytelny dla efektywnego identyfikatora użytkownika lub grupy? |
21 | -s Zwraca rozmiar pliku, zerowy rozmiar = pusty plik. |
22 | -t Czy uchwyt pliku jest otwarty przez TTY (terminal)? |
23 | -u Czy plik ma ustawiony bit setuid? |
24 | -w Czy efektywny identyfikator użytkownika lub grupy ma możliwość zapisu w pliku? |
25 | -x Czy plik jest wykonywalny przez efektywnego identyfikatora użytkownika lub grupy? |
26 | -z Czy rozmiar pliku wynosi zero? |
Poniżej przedstawiono standardowe funkcje używane do zabawy z katalogami.
opendir DIRHANDLE, EXPR # To open a directory
readdir DIRHANDLE # To read a directory
rewinddir DIRHANDLE # Positioning pointer to the begining
telldir DIRHANDLE # Returns current position of the dir
seekdir DIRHANDLE, POS # Pointing pointer to POS inside dir
closedir DIRHANDLE # Closing a directory.
Wyświetl wszystkie pliki
Istnieją różne sposoby wyświetlania listy wszystkich plików dostępnych w określonym katalogu. Najpierw użyjmy prostego sposobu, aby pobrać i wyświetlić listę wszystkich plików za pomocą rozszerzeniaglob operator -
#!/usr/bin/perl
# Display all the files in /tmp directory.
$dir = "/tmp/*"; my @files = glob( $dir );
foreach (@files ) {
print $_ . "\n"; } # Display all the C source files in /tmp directory. $dir = "/tmp/*.c";
@files = glob( $dir ); foreach (@files ) { print $_ . "\n";
}
# Display all the hidden files.
$dir = "/tmp/.*"; @files = glob( $dir );
foreach (@files ) {
print $_ . "\n"; } # Display all the files from /tmp and /home directories. $dir = "/tmp/* /home/*";
@files = glob( $dir ); foreach (@files ) { print $_ . "\n";
}
Oto kolejny przykład, który otwiera katalog i wyświetla listę wszystkich plików dostępnych w tym katalogu.
#!/usr/bin/perl
opendir (DIR, '.') or die "Couldn't open directory, $!"; while ($file = readdir DIR) {
print "$file\n";
}
closedir DIR;
Jeszcze jeden przykład wydrukowania listy plików źródłowych C, których możesz użyć, to -
#!/usr/bin/perl
opendir(DIR, '.') or die "Couldn't open directory, $!";
foreach (sort grep(/^.*\.c$/,readdir(DIR))) { print "$_\n";
}
closedir DIR;
Utwórz nowy katalog
Możesz użyć mkdirfunkcja, aby utworzyć nowy katalog. Będziesz musiał mieć wymagane uprawnienia, aby utworzyć katalog.
#!/usr/bin/perl
$dir = "/tmp/perl"; # This creates perl directory in /tmp directory. mkdir( $dir ) or die "Couldn't create $dir directory, $!";
print "Directory created successfully\n";
Usuń katalog
Możesz użyć rmdirfunkcja usuwania katalogu. Aby usunąć katalog, musisz mieć wymagane uprawnienia. Dodatkowo ten katalog powinien być pusty, zanim spróbujesz go usunąć.
#!/usr/bin/perl
$dir = "/tmp/perl"; # This removes perl directory from /tmp directory. rmdir( $dir ) or die "Couldn't remove $dir directory, $!";
print "Directory removed successfully\n";
Zmień katalog
Możesz użyć chdirfunkcja, aby zmienić katalog i przejść do nowej lokalizacji. Będziesz musiał mieć wymagane uprawnienia, aby zmienić katalog i wejść do nowego katalogu.
#!/usr/bin/perl
$dir = "/home"; # This changes perl directory and moves you inside /home directory. chdir( $dir ) or die "Couldn't go inside $dir directory, $!";
print "Your new location is $dir\n";
Wykonanie i błędy zawsze idą w parze. Jeśli otwierasz plik, który nie istnieje. wtedy jeśli nie poradziłeś sobie z tą sytuacją poprawnie, twój program zostanie uznany za złej jakości.
Program zatrzymuje się, jeśli wystąpi błąd. Tak więc odpowiednia obsługa błędów jest używana do obsługi różnego rodzaju błędów, które mogą wystąpić podczas wykonywania programu i podjęcia odpowiednich działań zamiast całkowitego zatrzymania programu.
Możesz zidentyfikować i złapać błąd na wiele różnych sposobów. Bardzo łatwo jest wychwycić błędy w Perlu, a następnie odpowiednio je obsłużyć. Oto kilka metod, które można zastosować.
Instrukcja if
Plik if statementjest oczywistym wyborem, gdy trzeba sprawdzić wartość zwracaną z instrukcji; na przykład -
if(open(DATA, $file)) {
...
} else {
die "Error: Couldn't open the file - $!";
}
Tutaj zmienna $! zwraca rzeczywisty komunikat o błędzie. Ewentualnie możemy zredukować instrukcję do jednej linii w sytuacjach, w których ma to sens; na przykład -
open(DATA, $file) || die "Error: Couldn't open the file $!";
Funkcja chyba że
Plik unlessfunkcja jest logicznym przeciwieństwem instrukcji if: może całkowicie ominąć status sukcesu i zostać wykonana tylko wtedy, gdy wyrażenie zwróci wartość false. Na przykład -
unless(chdir("/etc")) {
die "Error: Can't change directory - $!";
}
Plik unlessInstrukcja jest najlepiej używana, gdy chcesz zgłosić błąd lub alternatywę tylko wtedy, gdy wyrażenie zawiedzie. Instrukcja ma również sens, gdy jest używana w instrukcji jednowierszowej -
die "Error: Can't change directory!: $!" unless(chdir("/etc"));
Tutaj umieramy tylko wtedy, gdy operacja chdir się nie powiedzie i ładnie się czyta.
Operator trójskładnikowy
W przypadku bardzo krótkich testów możesz użyć operatora warunkowego ?:
print(exists($hash{value}) ? 'There' : 'Missing',"\n");
Nie jest tutaj do końca jasne, co staramy się osiągnąć, ale efekt jest taki sam, jak użycie pliku if lub unlesskomunikat. Operatora warunkowego najlepiej używać, gdy chcesz szybko zwrócić jedną z dwóch wartości w wyrażeniu lub instrukcji.
Funkcja ostrzeżenia
Funkcja ostrzegania po prostu generuje ostrzeżenie, komunikat jest drukowany do STDERR, ale nie są podejmowane żadne dalsze działania. Jest to więc bardziej przydatne, jeśli chcesz po prostu wydrukować ostrzeżenie dla użytkownika i kontynuować resztę operacji -
chdir('/etc') or warn "Can't change directory";
Funkcja matrycy
Funkcja matrycy działa podobnie jak warn, z wyjątkiem tego, że wywołuje również wyjście. W zwykłym skrypcie funkcja ta powoduje natychmiastowe przerwanie wykonywania. Powinieneś użyć tej funkcji na wypadek, gdyby nie było sensu kontynuować, jeśli w programie wystąpił błąd -
chdir('/etc') or die "Can't change directory";
Błędy w modułach
Są dwie różne sytuacje, z którymi powinniśmy sobie poradzić -
Zgłaszanie błędu w module, który cytuje nazwę pliku modułu i numer wiersza - jest to przydatne podczas debugowania modułu lub gdy konkretnie chcesz zgłosić błąd związany z modułem, a nie ze skryptem.
Zgłaszanie błędu w module, który cytuje informacje o dzwoniącym, aby można było debugować wiersz w skrypcie, który spowodował błąd. Błędy zgłoszone w ten sposób są przydatne dla użytkownika końcowego, ponieważ podkreślają błąd w odniesieniu do wiersza źródłowego skryptu wywołującego.
Plik warn i diefunkcje działają nieco inaczej niż można by oczekiwać, gdy są wywoływane z poziomu modułu. Na przykład prosty moduł -
package T;
require Exporter;
@ISA = qw/Exporter/;
@EXPORT = qw/function/;
use Carp;
sub function {
warn "Error in module!";
}
1;
W przypadku wywołania ze skryptu jak poniżej -
use T;
function();
To da następujący wynik -
Error in module! at T.pm line 9.
To mniej więcej to, czego mógłbyś się spodziewać, ale niekoniecznie to, czego chcesz. Z punktu widzenia programisty modułów informacje są przydatne, ponieważ pomagają wskazać błąd w samym module. Dla użytkownika końcowego podane informacje są dość bezużyteczne, a dla wszystkich, z wyjątkiem zatwardziałego programisty, są całkowicie bezcelowe.
Rozwiązaniem takich problemów jest moduł Carp, który zapewnia uproszczoną metodę raportowania błędów w modułach zwracających informacje o skrypcie wywołującym. Moduł Karp zapewnia cztery funkcje: karp, gdakanie, rechotanie i wyznanie. Funkcje te omówiono poniżej.
Funkcja karpia
Funkcja karp jest podstawowym odpowiednikiem ostrzeżenia i wyświetla wiadomość do STDERR bez faktycznego wychodzenia ze skryptu i drukowania nazwy skryptu.
package T;
require Exporter;
@ISA = qw/Exporter/;
@EXPORT = qw/function/;
use Carp;
sub function {
carp "Error in module!";
}
1;
W przypadku wywołania ze skryptu jak poniżej -
use T;
function();
To da następujący wynik -
Error in module! at test.pl line 4
Funkcja Cluck
Funkcja cluck jest rodzajem superdoładowanego karpia, działa zgodnie z tą samą podstawową zasadą, ale także drukuje ślad stosu wszystkich modułów, które doprowadziły do wywołania funkcji, w tym informacje o oryginalnym skrypcie.
package T;
require Exporter;
@ISA = qw/Exporter/;
@EXPORT = qw/function/;
use Carp qw(cluck);
sub function {
cluck "Error in module!";
}
1;
W przypadku wywołania ze skryptu jak poniżej -
use T;
function();
To da następujący wynik -
Error in module! at T.pm line 9
T::function() called at test.pl line 4
Funkcja rechotania
Plik croak funkcja jest równoważna die, z wyjątkiem tego, że zgłasza dzwoniącego o jeden poziom wyżej. Podobnie jak die, ta funkcja również zamyka skrypt po zgłoszeniu błędu do STDERR -
package T;
require Exporter;
@ISA = qw/Exporter/;
@EXPORT = qw/function/;
use Carp;
sub function {
croak "Error in module!";
}
1;
W przypadku wywołania ze skryptu jak poniżej -
use T;
function();
To da następujący wynik -
Error in module! at test.pl line 4
Podobnie jak w przypadku karpia, obowiązują te same podstawowe zasady dotyczące uwzględniania informacji o liniach i plikach zgodnie z funkcjami ostrzeżenia i matrycy.
Funkcja wyznania
Plik confess funkcja jest jak cluck; wywołuje die, a następnie drukuje ślad stosu aż do skryptu źródłowego.
package T;
require Exporter;
@ISA = qw/Exporter/;
@EXPORT = qw/function/;
use Carp;
sub function {
confess "Error in module!";
}
1;
W przypadku wywołania ze skryptu jak poniżej -
use T;
function();
To da następujący wynik -
Error in module! at T.pm line 9
T::function() called at test.pl line 4
Istnieje kilka zmiennych, które mają predefiniowane i specjalne znaczenie w Perlu. Są to zmienne, które używają znaków interpunkcyjnych po zwykłym wskaźniku zmiennej ($, @ lub%), takim jak $ _ (wyjaśnione poniżej).
Większość zmiennych specjalnych ma angielskie nazwy, np. Długie nazwy, np. Zmienna błędu systemu operacyjnego $! można zapisać jako $ OS_ERROR. Ale jeśli zamierzasz używać nazw podobnych do angielskiego, musisz umieścić jedną linięuse English;u góry pliku programu. To prowadzi interpretera do określenia dokładnego znaczenia zmiennej.
Najczęściej używaną zmienną specjalną jest $ _, która zawiera domyślne dane wejściowe i ciąg znaków wyszukiwania. Na przykład w następujących wierszach -
#!/usr/bin/perl
foreach ('hickory','dickory','doc') {
print $_;
print "\n";
}
Po uruchomieniu da to następujący wynik -
hickory
dickory
doc
Ponownie sprawdźmy ten sam przykład bez jawnego użycia zmiennej $ _ -
#!/usr/bin/perl
foreach ('hickory','dickory','doc') {
print;
print "\n";
}
Po wykonaniu spowoduje to również następujący wynik -
hickory
dickory
doc
Gdy pętla jest wykonywana po raz pierwszy, drukowany jest napis „hickory”. Za drugim razem drukowany jest „dickory”, a za trzecim „doc”. Dzieje się tak, ponieważ w każdej iteracji pętli bieżący ciąg jest umieszczany w$_, and is used by default by print. Here are the places where Perl will assume $_ nawet jeśli tego nie określisz -
Różne funkcje jednoargumentowe, w tym funkcje takie jak ord i int, a także wszystkie testy plików (-f, -d) z wyjątkiem -t, które domyślnie jest STDIN.
Różne funkcje list, takie jak drukowanie i odłączanie.
Operacje dopasowywania wzorców m //, s /// i tr /// używane bez operatora = ~.
Domyślna zmienna iteratora w pętli foreach, jeśli nie podano żadnej innej zmiennej.
Niejawna zmienna iteratora w funkcjach grep i map.
Domyślne miejsce umieszczenia rekordu wejściowego, gdy wynik operacji wejścia liniowego jest testowany samodzielnie jako jedyne kryterium testu while (tj.). Zauważ, że poza chwilowym testem tak się nie stanie.
Specjalne typy zmiennych
W oparciu o wykorzystanie i charakter zmiennych specjalnych możemy podzielić je na następujące kategorie -
- Globalne zmienne specjalne skalarne.
- Globalne zmienne specjalne tablicy.
- Global Hash Special Variables.
- Globalne uchwyty plików specjalnych.
- Globalne stałe specjalne.
- Zmienne specjalne wyrażeń regularnych.
- Zmienne specjalne Filehandle.
Globalne zmienne specjalne skalarne
Oto lista wszystkich skalarnych zmiennych specjalnych. Wymieniliśmy odpowiadające im angielskie nazwy wraz z nazwami symbolicznymi.
$ _ | Domyślna przestrzeń wejściowa i przestrzeń wyszukiwania wzorców. |
$ ARG | |
$. | Bieżący numer wiersza wejściowego ostatniego odczytanego uchwytu pliku. Jawne zamknięcie uchwytu pliku resetuje numer wiersza. |
$ NR | |
$ / | Separator rekordów wejściowych; nowa linia domyślnie. Jeśli jest ustawiony na ciąg pusty, traktuje puste wiersze jako ograniczniki. |
$ RS | |
$, | Separator pól wyjściowych dla operatora drukowania. |
$ OFS | |
$ \ | Separator rekordów wyjściowych dla operatora drukowania. |
$ ORS | |
$ " | Podobnie jak „$”, z tą różnicą, że odnosi się do wartości list interpolowanych do łańcucha umieszczonego w cudzysłowie (lub podobnego zinterpretowanego ciągu). Domyślnie jest to spacja. |
$ LIST_SEPARATOR | |
$; | Separator indeksu dolnego dla emulacji wielowymiarowej tablicy. Wartość domyślna to „\ 034”. |
$ SUBSCRIPT_SEPARATOR | |
$ ^ L. | Jaki format generuje w celu wykonania wysuwu formularza. Domyślnie jest to „\ f”. |
$ FORMAT_FORMFEED | |
$: | Bieżący zestaw znaków, po którym można przerwać ciąg w celu wypełnienia pól kontynuacyjnych (zaczynając od ^) w formacie. Wartość domyślna to „\ n” ”. |
$ FORMAT_LINE_BREAK_CHARACTERS | |
$ ^ A | Bieżąca wartość akumulatora zapisu dla linii formatu. |
$ ACCUMULATOR | |
$ # | Zawiera format wyjściowy dla drukowanych liczb (przestarzały). |
$ OFMT | |
$? | Stan zwrócony przez ostatnie zamknięcie potoku, polecenie cofnięcia (``) lub operatora systemu. |
$ CHILD_ERROR | |
$! | Jeśli jest używany w kontekście numerycznym, zwraca bieżącą wartość zmiennej errno, identyfikując ostatni błąd wywołania systemowego. Jeśli jest używany w kontekście ciągów, zwraca odpowiedni ciąg błędu systemu. |
$OS_ERROR or $ERRNO | |
$ @ | Komunikat o błędzie składni Perla z ostatniego polecenia eval. |
$ EVAL_ERROR | |
$$ | Identyfikator pid procesu Perl, który uruchamia ten skrypt. |
$ PROCESS_ID lub $ PID | |
$ < | Rzeczywisty identyfikator użytkownika (uid) tego procesu. |
$REAL_USER_ID or $UID | |
$> | Efektywny identyfikator użytkownika tego procesu. |
$ EFFECTIVE_USER_ID lub $ EUID | |
$ ( | Rzeczywisty identyfikator grupy (gid) tego procesu. |
$REAL_GROUP_ID or $KOŁOWACIZNA | |
$) | Efektywny gid tego procesu. |
$ EFFECTIVE_GROUP_ID lub $ EGID | |
0 USD | Zawiera nazwę pliku zawierającego wykonywany skrypt Perla. |
$ PROGRAM_NAME | |
$ [ | Indeks pierwszego elementu tablicy i pierwszego znaku w podciągu. Wartość domyślna to 0. |
$] | Zwraca wersję wraz z poziomem poprawek podzieloną przez 1000. |
$ PERL_VERSION | |
$ ^ D | Bieżąca wartość flag debugowania. |
$ DEBUGOWANIE | |
$ ^ E | Rozszerzony komunikat o błędzie na niektórych platformach. |
$ EXTENDED_OS_ERROR | |
$ ^ F. | Maksymalny deskryptor pliku systemowego, zwykle 2. |
$ SYSTEM_FD_MAX | |
$ ^ H | Zawiera wewnętrzne wskazówki kompilatora włączone przez niektóre pragmatyczne moduły. |
$ ^ I | Bieżąca wartość rozszerzenia edycji w miejscu. Użyj undef, aby wyłączyć edycję w miejscu. |
$ INPLACE_EDIT | |
$ ^ Mln | Zawartość $M can be used as an emergency memory pool in case Perl dies with an out-of-memory error. Use of $M wymaga specjalnej kompilacji Perla. Zobacz dokument INSTALACJA, aby uzyskać więcej informacji. |
$ ^ O | Zawiera nazwę systemu operacyjnego, dla którego został skompilowany bieżący plik binarny Perl. |
$ OSNAME | |
$ ^ P | Wewnętrzna flaga, którą debuger czyści, aby sam nie debugował. |
$ PERLDB | |
$ ^ T | Czas, w którym skrypt zaczął działać, w sekundach od epoki. |
$ BASETIME | |
$ ^ W. | Bieżąca wartość przełącznika ostrzeżenia, prawda lub fałsz. |
$ OSTRZEŻENIE | |
$ ^ X | Nazwa, pod jaką został wykonany plik binarny Perla. |
$ EXECUTABLE_NAME | |
$ ARGV | Zawiera nazwę bieżącego pliku podczas odczytu z <ARGV>. |
Globalne zmienne specjalne tablicy
@ARGV | Tablica zawierająca argumenty wiersza poleceń przeznaczone dla skryptu. |
@INC | Tablica zawierająca listę miejsc, w których należy szukać skryptów Perla do oceny przez konstrukcje do, require lub use. |
@FA | Tablica, na którą dzielone są wiersze wejściowe, gdy podano przełącznik wiersza poleceń -a. |
Global Hash Special Variables
% INC | Skrót zawierający wpisy dla nazwy każdego pliku, który został dołączony za pomocą polecenia do lub require. |
% ENV | Skrót zawierający bieżące środowisko. |
% SIG | Skrót używany do ustawiania programów obsługi sygnałów dla różnych sygnałów. |
Globalne uchwyty plików specjalnych
ARGV | Specjalny uchwyt pliku, który iteruje po nazwach plików w wierszu poleceń w @ARGV. Zwykle zapisywany jako pusty uchwyt pliku w <>. |
STDERR | Specjalny uchwyt pliku dla standardowego błędu w dowolnym pakiecie. |
STDIN | Specjalny uchwyt pliku do standardowego wejścia w dowolnym pakiecie. |
STDOUT | Specjalny uchwyt pliku dla standardowego wyjścia w dowolnym pakiecie. |
DANE | Specjalny uchwyt pliku, który odnosi się do wszystkiego, co następuje po tokenie __END__ w pliku zawierającym skrypt. Lub specjalny uchwyt pliku dla wszystkiego, co następuje po tokenie __DATA__ w wymaganym pliku, o ile czytasz dane z tego samego pakietu, w którym znaleziono __DATA__. |
_ (podkreślenie) | Specjalny uchwyt pliku używany do buforowania informacji z ostatniego operatora testu stat, lstat lub pliku. |
Globalne stałe specjalne
__KONIEC__ | Wskazuje logiczny koniec programu. Każdy następujący tekst jest ignorowany, ale można go odczytać za pomocą uchwytu pliku DATA. |
__PLIK__ | Reprezentuje nazwę pliku w punkcie programu, w którym jest używany. Nie interpolowano na ciągi. |
__LINIA__ | Reprezentuje bieżący numer wiersza. Nie interpolowano na ciągi. |
__PAKIET__ | Reprezentuje bieżącą nazwę pakietu w czasie kompilacji lub undefined, jeśli nie ma bieżącego pakietu. Nie interpolowano na ciągi. |
Zmienne specjalne wyrażeń regularnych
$ cyfra | Zawiera tekst dopasowany przez odpowiedni zestaw nawiasów w ostatnim dopasowanym wzorcu. Na przykład $ 1 pasuje do tego, co było zawarte w pierwszym zestawie nawiasów w poprzednim wyrażeniu regularnym. |
$ & | Ciąg dopasowany przez ostatnie udane dopasowanie wzorca. |
$ MATCH | |
$ ` | Ciąg poprzedzający wszystko, co zostało dopasowane przez ostatnie udane dopasowanie wzorca. |
$ PREMATCH | |
$ ' | Ciąg następujący po tym, co został dopasowany przez ostatnie udane dopasowanie wzorca. |
$ POSTMATCH | |
$ + | Ostatni nawias dopasowany przez ostatni wzorzec wyszukiwania. Jest to przydatne, jeśli nie wiesz, który z zestawu alternatywnych wzorców został dopasowany. Na przykład: / Wersja: (. *) | Wersja: (. *) / && ($rev = $+); |
$ LAST_PAREN_MATCH |
Zmienne specjalne Filehandle
$ | | Jeśli ustawione na wartość niezerową, wymusza fflush (3) po każdym zapisie lub wydruku na aktualnie wybranym kanale wyjściowym. |
$ OUTPUT_AUTOFLUSH | |
% $ | Numer bieżącej strony aktualnie wybranego kanału wyjściowego. |
$ FORMAT_PAGE_NUMBER | |
$ = | Bieżąca długość strony (linie do wydrukowania) aktualnie wybranego kanału wyjściowego. Wartość domyślna to 60. |
$ FORMAT_LINES_PER_PAGE | |
$ - | Liczba wierszy pozostałych na stronie aktualnie wybranego kanału wyjściowego. |
$ FORMAT_LINES_LEFT | |
$ ~ | Nazwa aktualnego formatu raportu dla aktualnie wybranego kanału wyjściowego. Domyślnie jest to nazwa uchwytu pliku. |
$ FORMAT_NAME | |
$ ^ | Nazwa bieżącego formatu początku strony dla aktualnie wybranego kanału wyjściowego. Domyślnie jest to nazwa uchwytu pliku z dołączonym _TOP. |
$ FORMAT_TOP_NAME |
Każdy programista będzie oczywiście miał własne preferencje dotyczące formatowania, ale istnieją pewne ogólne wskazówki, które ułatwią czytanie, zrozumienie i konserwację programów.
Najważniejszą rzeczą jest uruchamianie programów przez cały czas z flagą -w. Możesz ją jawnie wyłączyć dla określonych części kodu za pomocą pragmy no warnings lub zmiennej $ ^ W, jeśli musisz. Powinieneś także zawsze korzystać z ograniczeń lub znać powód, dla którego nie. Przydatne może się też okazać zastosowanie pułapki użycia, a nawet pragmaty diagnostyki użycia.
Jeśli chodzi o estetykę układu kodu, jedyną rzeczą, na której bardzo zależy Larry'emu, jest to, aby zamykający nawias klamrowy wielowierszowego BLOKU był zgodny ze słowem kluczowym, które rozpoczęło konstrukcję. Poza tym ma inne preferencje, które nie są tak silne -
- Wcięcie 4-kolumnowe.
- Otwarcie kręcone w tym samym wierszu co słowo kluczowe, jeśli to możliwe, w przeciwnym razie ustaw.
- Spacja przed początkiem kręcenia BLOKU wieloliniowego.
- Jednowierszowy BLOK może być umieszczony na jednej linii, łącznie z zawijasami.
- Brak spacji przed średnikiem.
- W „krótkim” jednowierszowym BLOKU pominięto średnik.
- Przestrzeń wokół większości operatorów.
- Spacja wokół „złożonego” indeksu dolnego (w nawiasach kwadratowych).
- Puste linie między fragmentami, które robią różne rzeczy.
- Uncuddled elses.
- Brak spacji między nazwą funkcji a nawiasem otwierającym.
- Spacja po każdym przecinku.
- Długie linie przerywane po operatorze (z wyjątkiem i i lub).
- Spacja po ostatnim dopasowaniu nawiasu w bieżącej linii.
- Ułóż odpowiednie elementy w pionie.
- Pomiń zbędne znaki interpunkcyjne, o ile nie ucierpi na tym klarowność.
Oto kilka innych, bardziej merytorycznych kwestii związanych ze stylem do przemyślenia: Tylko dlatego, że MOŻESZ zrobić coś w określony sposób, nie oznacza, że POWINIENEŚ to zrobić w ten sposób. Perl ma na celu dać ci kilka sposobów na zrobienie czegokolwiek, więc rozważ wybranie najbardziej czytelnego. Na przykład -
open(FOO,$foo) || die "Can't open $foo: $!";
Jest lepszy niż -
die "Can't open $foo: $!" unless open(FOO,$foo);
Ponieważ drugi sposób ukrywa główny punkt instrukcji w modyfikatorze. Z drugiej strony,
print "Starting analysis\n" if $verbose;
Jest lepszy niż -
$verbose && print "Starting analysis\n";
Ponieważ głównym punktem nie jest to, czy użytkownik wpisał -v, czy nie.
Nie przechodź przez głupie wygięcia, aby wyjść z pętli na górze lub na dole, kiedy Perl zapewnia ostatni operator, dzięki czemu możesz wyjść w środku. Po prostu „zdezaktualizuj” go trochę, aby był bardziej widoczny -
LINE:
for (;;) {
statements;
last LINE if $foo;
next LINE if /^#/;
statements;
}
Zobaczmy kilka ważniejszych punktów -
Nie bój się używać etykiet pętli - mają one na celu zwiększenie czytelności, a także umożliwienie wielopoziomowego przerywania pętli. Zobacz poprzedni przykład.
Unikaj używania grep () (lub map ()) lub `backticks` w kontekście void, czyli wtedy, gdy po prostu odrzucasz ich wartości zwracane. Wszystkie te funkcje mają wartości zwracane, więc używaj ich. W przeciwnym razie użyj zamiast tego pętli foreach () lub funkcji system ().
Aby zapewnić przenośność, podczas korzystania z funkcji, które mogą nie być zaimplementowane na każdym komputerze, przetestuj konstrukcję w ewaluacji, aby sprawdzić, czy się nie powiedzie. Jeśli wiesz, jaka wersja lub poziom poprawek została zaimplementowana dana funkcja, możesz przetestować $] ($ PERL_VERSION w języku angielskim), aby sprawdzić, czy tam będzie. Moduł Config pozwala również na sprawdzanie wartości określonych przez program Configure podczas instalacji Perla.
Wybierz identyfikatory mnemoniczne. Jeśli nie pamiętasz, co oznacza mnemonik, masz problem.
Chociaż krótkie identyfikatory, takie jak $ gotit, prawdopodobnie są w porządku, użyj podkreśleń, aby oddzielić słowa w dłuższych identyfikatorach. Generalnie jest łatwiejszy do odczytania$var_names_like_this than $VarNamesLikeThis, szczególnie dla osób, dla których angielski nie jest językiem ojczystym. Jest to również prosta reguła, która działa spójnie z VAR_NAMES_LIKE_THIS.
Nazwy pakietów są czasami wyjątkiem od tej reguły. Perl nieformalnie rezerwuje nazwy modułów pisane małymi literami dla modułów „pragma”, takich jak liczba całkowita i ścisłe. Inne moduły powinny zaczynać się wielką literą i używać mieszanych wielkości liter, ale prawdopodobnie bez podkreślenia ze względu na ograniczenia w reprezentacji nazw modułów przez prymitywne systemy plików jako pliki, które muszą mieścić się w kilku rzadkich bajtach.
Jeśli masz naprawdę włochate wyrażenie regularne, użyj modyfikatora / x i wstaw trochę białych znaków, aby wyglądało trochę mniej jak szum linii. Nie używaj ukośnika jako separatora, gdy wyrażenie regularne zawiera ukośniki lub odwrotne ukośniki.
Zawsze sprawdzaj kody zwrotne wywołań systemowych. Dobre komunikaty o błędach powinny trafiać do STDERR, zawierać informację o tym, który program spowodował problem, jakie były błędne wywołania systemowe i argumenty oraz (BARDZO WAŻNE) powinny zawierać standardowy komunikat o błędzie systemowym opisujący, co poszło nie tak. Oto prosty, ale wystarczający przykład -
opendir(D, $dir) or die "can't opendir $dir: $!";
Pomyśl o możliwości ponownego wykorzystania. Po co marnować siłę mózgu na jednorazową pracę, skoro możesz chcieć zrobić coś podobnego jeszcze raz? Rozważ uogólnienie kodu. Rozważ napisanie modułu lub klasy obiektów. Rozważ sprawienie, aby kod działał czysto, używając ścisłych zasad i ostrzeżeń (lub -w). Rozważ rozdanie swojego kodu. Rozważ zmianę całego poglądu na świat. Rozważ ... och, nieważne.
Bądź konsekwentny.
Bądź miły.
Wyrażenie regularne to ciąg znaków definiujący wyświetlany wzorzec lub wzorce. Składnia wyrażeń regularnych w Perlu jest bardzo podobna do tego, co znajdziesz w innych programach obsługujących wyrażenia regularne, takich jaksed, grep, i awk.
Podstawową metodą stosowania wyrażenia regularnego jest użycie operatorów wiązania wzorca = ~ i !~. Pierwszy operator to operator testu i przypisania.
W Perlu są trzy operatory wyrażeń regularnych.
- Dopasuj wyrażenie regularne - m //
- Zastąpienie wyrażenia regularnego - s ///
- Transliteracja wyrażenia regularnego - tr ///
W każdym przypadku ukośniki działają jak ograniczniki wyrażenia regularnego (regex), które określasz. Jeśli nie przeszkadza Ci inny separator, możesz użyć zamiast ukośnika.
Operator dopasowania
Operator dopasowania, m //, służy do dopasowania ciągu lub instrukcji do wyrażenia regularnego. Na przykład, aby dopasować sekwencję znaków „foo” do skalarnego baru $ bar, możesz użyć takiego oświadczenia -
#!/usr/bin/perl
$bar = "This is foo and again foo"; if ($bar =~ /foo/) {
print "First time is matching\n";
} else {
print "First time is not matching\n";
}
$bar = "foo"; if ($bar =~ /foo/) {
print "Second time is matching\n";
} else {
print "Second time is not matching\n";
}
Wykonanie powyższego programu daje następujący wynik -
First time is matching
Second time is matching
M // faktycznie działa w ten sam sposób, co seria operatorów q //. Możesz użyć dowolnej kombinacji naturalnie pasujących znaków, aby działać jako ograniczniki wyrażenia. Na przykład m {}, m () i m> <są prawidłowe. Tak więc powyższy przykład można przepisać w następujący sposób -
#!/usr/bin/perl
$bar = "This is foo and again foo"; if ($bar =~ m[foo]) {
print "First time is matching\n";
} else {
print "First time is not matching\n";
}
$bar = "foo"; if ($bar =~ m{foo}) {
print "Second time is matching\n";
} else {
print "Second time is not matching\n";
}
Możesz pominąć m z m //, jeśli separatory są ukośnikami, ale dla wszystkich innych separatorów musisz użyć przedrostka m.
Zwróć uwagę, że całe wyrażenie dopasowujące, to jest wyrażenie po lewej stronie = ~ lub! ~ I operator dopasowania, zwraca wartość true (w kontekście skalarnym), jeśli wyrażenie pasuje. Dlatego oświadczenie -
$true = ($foo =~ m/foo/);
ustawi $true to 1 if $foo pasuje do wyrażenia regularnego lub 0, jeśli dopasowanie się nie powiedzie. W kontekście listowym dopasowanie zwraca zawartość wszystkich zgrupowanych wyrażeń. Na przykład podczas wyodrębniania godzin, minut i sekund z ciągu czasu możemy użyć -
my ($hours, $minutes, $seconds) = ($time =~ m/(\d+):(\d+):(\d+)/);
Dopasuj modyfikatory operatorów
Operator dopasowania obsługuje własny zestaw modyfikatorów. Modyfikator / g umożliwia dopasowanie globalne. Modyfikator / i sprawi, że w dopasowaniu wielkość liter będzie niewrażliwa. Oto pełna lista modyfikatorów
Sr.No. | Modyfikator i opis |
---|---|
1 | i Sprawia, że wielkość liter w dopasowaniu jest niewrażliwa. |
2 | m Określa, że jeśli ciąg zawiera znaki nowej linii lub powrotu karetki, operatory ^ i $ będą teraz dopasowywać się do granicy nowej linii, a nie do granicy ciągu. |
3 | o Oblicza wyrażenie tylko raz. |
4 | s Umożliwia korzystanie z. aby dopasować znak nowej linii. |
5 | x Umożliwia użycie spacji w wyrażeniu w celu zwiększenia przejrzystości. |
6 | g Globalnie znajduje wszystkie dopasowania. |
7 | cg Umożliwia kontynuowanie wyszukiwania nawet po niepowodzeniu globalnego dopasowania. |
Dopasowanie tylko raz
Istnieje również prostsza wersja operatora dopasowania -? WZÓR? operator. Jest to w zasadzie identyczne z operatorem m //, z wyjątkiem tego, że pasuje tylko raz w ciągu szukanym między każdym wywołaniem resetowania.
Na przykład możesz użyć tego, aby uzyskać pierwszy i ostatni element listy -
#!/usr/bin/perl
@list = qw/food foosball subeo footnote terfoot canic footbrdige/;
foreach (@list) {
$first = $1 if /(foo.*?)/; $last = $1 if /(foo.*)/; } print "First: $first, Last: $last\n";
Wykonanie powyższego programu daje następujący wynik -
First: foo, Last: footbrdige
Zmienne wyrażeń regularnych
Zmienne wyrażeń regularnych obejmują $, który zawiera ostatnie dopasowane dopasowanie grupujące; $&, który zawiera cały dopasowany ciąg; $`, który zawiera wszystko przed dopasowanym ciągiem; i$', który zawiera wszystko po dopasowanym ciągu. Poniższy kod demonstruje wynik -
#!/usr/bin/perl
$string = "The food is in the salad bar";
$string =~ m/foo/; print "Before: $`\n";
print "Matched: $&\n"; print "After: $'\n";
Wykonanie powyższego programu daje następujący wynik -
Before: The
Matched: foo
After: d is in the salad bar
Operator podstawienia
Operator podstawienia, s ///, jest tak naprawdę tylko rozszerzeniem operatora dopasowania, które pozwala zastąpić dopasowany tekst jakimś nowym tekstem. Podstawowa forma operatora to -
s/PATTERN/REPLACEMENT/;
WZÓR to wyrażenie regularne dla szukanego tekstu. REPLACEMENT to specyfikacja tekstu lub wyrażenia regularnego, którego chcemy użyć do zastąpienia znalezionego tekstu. Na przykład możemy zastąpić wszystkie wystąpieniadog z cat używając następującego wyrażenia regularnego -
#/user/bin/perl
$string = "The cat sat on the mat"; $string =~ s/cat/dog/;
print "$string\n";
Wykonanie powyższego programu daje następujący wynik -
The dog sat on the mat
Modyfikatory operatorów substytucji
Oto lista wszystkich modyfikatorów używanych z operatorem podstawiania.
Sr.No. | Modyfikator i opis |
---|---|
1 | i Sprawia, że wielkość liter w dopasowaniu jest niewrażliwa. |
2 | m Określa, że jeśli ciąg zawiera znaki nowej linii lub powrotu karetki, operatory ^ i $ będą teraz dopasowywać się do granicy nowej linii, a nie do granicy ciągu. |
3 | o Oblicza wyrażenie tylko raz. |
4 | s Umożliwia korzystanie z. aby dopasować znak nowej linii. |
5 | x Umożliwia użycie spacji w wyrażeniu w celu zwiększenia przejrzystości. |
6 | g Zamienia wszystkie wystąpienia znalezionego wyrażenia na tekst zastępczy. |
7 | e Ocenia zamianę tak, jakby była instrukcją Perla i używa jej wartości zwracanej jako tekstu zastępczego. |
Operator tłumaczenia
Tłumaczenie jest podobne, ale nie identyczne, do zasad podstawiania, ale w przeciwieństwie do podstawiania, transliteracja (lub transliteracja) nie używa wyrażeń regularnych do wyszukiwania wartości zastępczych. Operatorami tłumaczenia są -
tr/SEARCHLIST/REPLACEMENTLIST/cds
y/SEARCHLIST/REPLACEMENTLIST/cds
Tłumaczenie zastępuje wszystkie wystąpienia znaków w SEARCHLIST odpowiednimi znakami w REPLACEMENTLIST. Na przykład za pomocą polecenia „Kot usiadł na macie”. ciąg, którego używaliśmy w tym rozdziale -
#/user/bin/perl
$string = 'The cat sat on the mat'; $string =~ tr/a/o/;
print "$string\n";
Wykonanie powyższego programu daje następujący wynik -
The cot sot on the mot.
Można również użyć standardowych zakresów Perla, co pozwala określić zakresy znaków według litery lub wartości liczbowej. Aby zmienić wielkość liter w ciągu, możesz użyć następującej składni zamiastuc funkcjonować.
$string =~ tr/a-z/A-Z/;
Modyfikatory operatora tłumaczenia
Poniżej znajduje się lista operatorów związanych z tłumaczeniem.
Sr.No. | Modyfikator i opis |
---|---|
1 | c Uzupełnia SEARCHLIST. |
2 | d Usuwa znalezione, ale niezastąpione znaki. |
3 | s Zgniata zduplikowane zastąpione znaki. |
Modyfikator / d usuwa znaki pasujące do LISTY WYSZUKIWANIA, które nie mają odpowiedniego wpisu w LISTA ZAMIENNIKÓW. Na przykład -
#!/usr/bin/perl
$string = 'the cat sat on the mat.'; $string =~ tr/a-z/b/d;
print "$string\n";
Wykonanie powyższego programu daje następujący wynik -
b b b.
Ostatni modyfikator / s usuwa zduplikowane sekwencje znaków, które zostały zastąpione, więc -
#!/usr/bin/perl
$string = 'food';
$string = 'food'; $string =~ tr/a-z/a-z/s;
print "$string\n";
Wykonanie powyższego programu daje następujący wynik -
fod
Bardziej złożone wyrażenia regularne
Nie musisz tylko dopasowywać się do ustalonych łańcuchów. W rzeczywistości możesz dopasować prawie wszystko, o czym możesz marzyć, używając bardziej złożonych wyrażeń regularnych. Oto krótka ściągawka -
W poniższej tabeli wymieniono składnię wyrażeń regularnych, która jest dostępna w języku Python.
Sr.No. | Wzór i opis |
---|---|
1 | ^ Pasuje do początku wiersza. |
2 | $ Pasuje do końca linii. |
3 | . Dopasowuje dowolny pojedynczy znak z wyjątkiem nowej linii. Użycie opcji m pozwala dopasować również znak nowej linii. |
4 | [...] Dopasowuje dowolny pojedynczy znak w nawiasach. |
5 | [^...] Dopasowuje dowolny pojedynczy znak nie w nawiasach. |
6 | * Dopasowuje 0 lub więcej wystąpień poprzedniego wyrażenia. |
7 | + Dopasowuje 1 lub więcej wystąpień poprzedniego wyrażenia. |
8 | ? Dopasowuje 0 lub 1 wystąpienie poprzedniego wyrażenia. |
9 | { n} Dopasowuje dokładnie n liczbę wystąpień poprzedniego wyrażenia. |
10 | { n,} Dopasowuje n lub więcej wystąpień poprzedniego wyrażenia. |
11 | { n, m} Pasuje do co najmniej n i co najwyżej m wystąpień poprzedniego wyrażenia. |
12 | a| b Pasuje do a lub b. |
13 | \w Dopasowuje znaki słowne. |
14 | \W Dopasowuje znaki inne niż słowa. |
15 | \s Pasuje do białych znaków. Odpowiednik [\ t \ n \ r \ f]. |
16 | \S Dopasowuje bez białych znaków. |
17 | \d Dopasowuje cyfry. Odpowiednik [0-9]. |
18 | \D Dopasowuje niecyfry. |
19 | \A Dopasowuje początek łańcucha. |
20 | \Z Dopasowuje koniec łańcucha. Jeśli istnieje nowa linia, pasuje ona tuż przed nową linią. |
21 | \z Dopasowuje koniec łańcucha. |
22 | \G Mecze to miejsce, w którym zakończył się ostatni mecz. |
23 | \b Dopasowuje granice wyrazów poza nawiasami. Dopasowuje znak Backspace (0x08) wewnątrz nawiasów. |
24 | \B Dopasowuje granice bez słów. |
25 | \n, \t, etc. Dopasowuje znaki nowej linii, powroty karetki, tabulatory itp. |
26 | \1...\9 Pasuje do n-tego zgrupowanego wyrażenia podrzędnego. |
27 | \10 Pasuje do n-tego zgrupowanego wyrażenia podrzędnego, jeśli zostało już dopasowane. W przeciwnym razie odnosi się do ósemkowej reprezentacji kodu znaku. |
28 | [aeiou] Dopasowuje pojedynczy znak w podanym zestawie |
29 | [^aeiou] Dopasowuje pojedynczy znak poza podanym zestawem |
Metaznak ^ pasuje do początku ciągu, a metasymbol $ do końca ciągu. Oto kilka krótkich przykładów.
# nothing in the string (start and end are adjacent)
/^$/
# a three digits, each followed by a whitespace
# character (eg "3 4 5 ")
/(\d\s) {3}/
# matches a string in which every
# odd-numbered letter is a (eg "abacadaf")
/(a.)+/
# string starts with one or more digits
/^\d+/
# string that ends with one or more digits
/\d+$/
Spójrzmy na inny przykład.
#!/usr/bin/perl
$string = "Cats go Catatonic\nWhen given Catnip";
($start) = ($string =~ /\A(.*?) /);
@lines = $string =~ /^(.*?) /gm; print "First word: $start\n","Line starts: @lines\n";
Wykonanie powyższego programu daje następujący wynik -
First word: Cats
Line starts: Cats When
Dopasowywanie granic
Plik \bdopasowuje na dowolnej granicy słowa, zdefiniowanej przez różnicę między klasą \ w a klasą \ W. Ponieważ \ w zawiera znaki słowa, a \ W odwrotnie, oznacza to zwykle zakończenie słowa. Plik\Basercja pasuje do każdej pozycji, która nie jest granicą słowa. Na przykład -
/\bcat\b/ # Matches 'the cat sat' but not 'cat on the mat'
/\Bcat\B/ # Matches 'verification' but not 'the cat on the mat'
/\bcat\B/ # Matches 'catatonic' but not 'polecat'
/\Bcat\b/ # Matches 'polecat' but not 'catatonic'
Wybór alternatyw
| znak jest taki sam, jak standardowy lub bitowy OR w Perlu. Określa alternatywne dopasowania w obrębie wyrażenia regularnego lub grupy. Na przykład, aby dopasować „kot” lub „pies” w wyrażeniu, możesz użyć tego -
if ($string =~ /cat|dog/)
Możesz grupować razem poszczególne elementy wyrażenia, aby obsługiwać złożone dopasowania. Wyszukiwanie nazwisk dwóch osób można przeprowadzić za pomocą dwóch oddzielnych testów, takich jak ten -
if (($string =~ /Martin Brown/) || ($string =~ /Sharon Brown/)) This could be written as follows if ($string =~ /(Martin|Sharon) Brown/)
Dopasowywanie grupowe
Z punktu widzenia wyrażeń regularnych nie ma różnicy między nimi, być może poza tym, że to pierwsze jest nieco jaśniejsze.
$string =~ /(\S+)\s+(\S+)/; and $string =~ /\S+\s+\S+/;
Jednak zaletą grupowania jest to, że pozwala nam wyodrębnić sekwencję z wyrażenia regularnego. Grupy są zwracane jako lista w kolejności, w jakiej występują w oryginale. Na przykład w poniższym fragmencie wyciągnęliśmy godziny, minuty i sekundy z łańcucha.
my ($hours, $minutes, $seconds) = ($time =~ m/(\d+):(\d+):(\d+)/);
Oprócz tej bezpośredniej metody, dopasowane grupy są również dostępne w ramach specjalnych zmiennych $ x, gdzie x jest numerem grupy w wyrażeniu regularnym. Moglibyśmy zatem przepisać powyższy przykład w następujący sposób -
#!/usr/bin/perl
$time = "12:05:30";
$time =~ m/(\d+):(\d+):(\d+)/; my ($hours, $minutes, $seconds) = ($1, $2, $3); print "Hours : $hours, Minutes: $minutes, Second: $seconds\n";
Wykonanie powyższego programu daje następujący wynik -
Hours : 12, Minutes: 05, Second: 30
Gdy grupy są używane w wyrażeniach podstawiania, w tekście zastępczym można użyć składni $ x. W ten sposób możemy ponownie sformatować ciąg daty, używając tego -
#!/usr/bin/perl
$date = '03/26/1999';
$date =~ s#(\d+)/(\d+)/(\d+)#$3/$1/$2#;
print "$date\n";
Wykonanie powyższego programu daje następujący wynik -
1999/03/26
Asercja \ G
Asercja \ G umożliwia kontynuowanie wyszukiwania od miejsca, w którym wystąpiło ostatnie dopasowanie. Na przykład w poniższym kodzie użyliśmy \ G, abyśmy mogli wyszukać właściwą pozycję, a następnie wyodrębnić niektóre informacje, bez konieczności tworzenia bardziej złożonego, pojedynczego wyrażenia regularnego -
#!/usr/bin/perl
$string = "The time is: 12:31:02 on 4/12/00";
$string =~ /:\s+/g; ($time) = ($string =~ /\G(\d+:\d+:\d+)/); $string =~ /.+\s+/g;
($date) = ($string =~ m{\G(\d+/\d+/\d+)});
print "Time: $time, Date: $date\n";
Wykonanie powyższego programu daje następujący wynik -
Time: 12:31:02, Date: 4/12/00
Asercja \ G jest właściwie metasymbolowym odpowiednikiem funkcji pos, więc między wywołaniami wyrażeń regularnych można nadal używać pos, a nawet modyfikować wartość pos (a tym samym \ G), używając pos jako podprogramu lvalue.
Przykłady wyrażeń regularnych
Znaki dosłowne
Sr.No. | Przykład i opis |
---|---|
1 | Perl Dopasuj „Perl”. |
Klasy postaci
Sr.No. | Przykład i opis |
---|---|
1 | [Pp]ython Pasuje do „Python” lub „python” |
2 | rub[ye] Dopasowuje „ruby” lub „rube” |
3 | [aeiou] Dopasowuje dowolną małą samogłoskę |
4 | [0-9] Dopasowuje dowolną cyfrę; tak samo jak [0123456789] |
5 | [a-z] Dopasowuje dowolną małą literę ASCII |
6 | [A-Z] Dopasowuje dowolną wielką literę ASCII |
7 | [a-zA-Z0-9] Pasuje do dowolnego z powyższych |
8 | [^aeiou] Dopasowuje wszystko inne niż mała samogłoska |
9 | [^0-9] Pasuje do wszystkiego innego niż cyfra |
Specjalne klasy postaci
Sr.No. | Przykład i opis |
---|---|
1 | . Dopasowuje dowolny znak z wyjątkiem nowej linii |
2 | \d Dopasowuje cyfrę: [0–9] |
3 | \D Odpowiada cyfrze: [^ 0-9] |
4 | \s Dopasowuje biały znak: [\ t \ r \ n \ f] |
5 | \S Dopasowuje bez białych znaków: [^ \ t \ r \ n \ f] |
6 | \w Dopasowuje pojedynczy znak słowa: [A-Za-z0-9_] |
7 | \W Dopasowuje znak niebędący słowem: [^ A-Za-z0-9_] |
Przypadki powtórzeń
Sr.No. | Przykład i opis |
---|---|
1 | ruby? Dopasowuje „rub” lub „ruby”: y jest opcjonalne |
2 | ruby* Dopasowuje „rub” plus 0 lub więcej lat |
3 | ruby+ Dopasowuje „rub” plus 1 lub więcej lat |
4 | \d{3} Dopasowuje dokładnie 3 cyfry |
5 | \d{3,} Dopasowuje 3 lub więcej cyfr |
6. | \d{3,5} Dopasowuje 3, 4 lub 5 cyfr |
Nongreedy Repetition
To pasuje do najmniejszej liczby powtórzeń -
Sr.No. | Przykład i opis |
---|---|
1 | <.*> Chciwe powtórzenie: dopasowuje „<python> perl>” |
2 | <.*?> Nongreedy: dopasowuje „<python>” w „<python> perl>” |
Grupowanie z nawiasami
Sr.No. | Przykład i opis |
---|---|
1 | \D\d+ Brak grupy: + powtarza \ d |
2 | (\D\d)+ Zgrupowane: + powtórzenia \ D \ d para |
3 | ([Pp]ython(, )?)+ Dopasuj „Python”, „Python, python, python” itp. |
Backreferences
To ponownie pasuje do poprzednio dopasowanej grupy -
Sr.No. | Przykład i opis |
---|---|
1 | ([Pp])ython&\1ails Pasuje do Python & Pails lub Python & Pails |
2 | (['"])[^\1]*\1 Ciąg w pojedynczym lub podwójnym cudzysłowie. \ 1 pasuje do dopasowanej pierwszej grupy. \ 2 pasuje do dopasowanej 2. grupy itd. |
Alternatywy
Sr.No. | Przykład i opis |
---|---|
1 | python|perl Dopasowuje „python” lub „perl” |
2 | rub(y|le)) Dopasowuje „rubin” lub „rubel” |
3 | Python(!+|\?) „Python”, po którym następuje jeden lub więcej! czy jeden? |
Kotwice
Ta potrzeba określenia pozycji dopasowania.
Sr.No. | Przykład i opis |
---|---|
1 | ^Python Dopasowuje „Python” na początku łańcucha lub linii wewnętrznej |
2 | Python$ Dopasowuje „Python” na końcu ciągu lub linii |
3 | \APython Dopasowuje „Python” na początku ciągu |
4 | Python\Z Dopasowuje „Python” na końcu ciągu |
5 | \bPython\b Dopasowuje „Python” na granicy słowa |
6 | \brub\B \ B nie jest granicą słów: dopasuj „rub” w „rube” i „ruby”, ale nie samodzielnie |
7 | Python(?=!) Dopasowuje „Python”, jeśli następuje po nim wykrzyknik |
8 | Python(?!!) Dopasowuje „Python”, jeśli nie następuje po nim wykrzyknik |
Specjalna składnia z nawiasami
Sr.No. | Przykład i opis |
---|---|
1 | R(?#comment) Pasuje do „R”. Cała reszta to komentarz |
2 | R(?i)uby Podczas dopasowywania „uby” bez rozróżniania wielkości liter |
3 | R(?i:uby) Tak samo jak powyżej |
4 | rub(?:y|le)) Grupuj tylko bez tworzenia \ 1 odwołania wstecznego |
Korzystanie z narzędzia sendmail
Wysyłanie zwykłej wiadomości
Jeśli pracujesz na komputerze z systemem Linux / Unix, możesz po prostu użyć sendmailnarzędzie w programie Perl do wysyłania wiadomości e-mail. Oto przykładowy skrypt, który może wysłać wiadomość e-mail na podany identyfikator e-mail. Upewnij się tylko, że podana ścieżka do narzędzia sendmail jest poprawna. To może być inne dla twojego komputera z systemem Linux / Unix.
#!/usr/bin/perl
$to = '[email protected]';
$from = '[email protected]'; $subject = 'Test Email';
$message = 'This is test email sent by Perl Script'; open(MAIL, "|/usr/sbin/sendmail -t"); # Email Header print MAIL "To: $to\n";
print MAIL "From: $from\n"; print MAIL "Subject: $subject\n\n";
# Email Body
print MAIL $message;
close(MAIL);
print "Email Sent Successfully\n";
W rzeczywistości powyższy skrypt jest skryptem poczty e-mail klienta, który sporządzi wersję roboczą wiadomości e-mail i prześle ją do serwera działającego lokalnie na komputerze z systemem Linux / Unix. Ten skrypt nie będzie odpowiedzialny za wysyłanie wiadomości e-mail do rzeczywistego miejsca docelowego. Musisz więc upewnić się, że serwer e-mail jest poprawnie skonfigurowany i działa na twoim komputerze, aby wysłać e-mail na podany identyfikator e-mail.
Wysyłanie wiadomości HTML
Jeśli chcesz wysłać wiadomość e-mail w formacie HTML za pomocą sendmaila, wystarczy dodać Content-type: text/html\n w części nagłówkowej wiadomości e-mail w następujący sposób -
#!/usr/bin/perl
$to = '[email protected]';
$from = '[email protected]'; $subject = 'Test Email';
$message = '<h1>This is test email sent by Perl Script</h1>'; open(MAIL, "|/usr/sbin/sendmail -t"); # Email Header print MAIL "To: $to\n";
print MAIL "From: $from\n"; print MAIL "Subject: $subject\n\n";
print MAIL "Content-type: text/html\n";
# Email Body
print MAIL $message;
close(MAIL);
print "Email Sent Successfully\n";
Korzystanie z modułu MIME :: Lite
Jeśli pracujesz na komputerze z systemem Windows, nie będziesz mieć dostępu do narzędzia sendmail. Ale masz alternatywę, aby napisać własnego klienta poczty e-mail za pomocą modułu MIME: Lite perl. Możesz pobrać ten moduł z MIME-Lite-3.01.tar.gz i zainstalować go na swoim komputerze z systemem Windows lub Linux / Unix. Aby go zainstalować, wykonaj proste czynności -
$tar xvfz MIME-Lite-3.01.tar.gz
$cd MIME-Lite-3.01 $perl Makefile.PL
$make $make install
To wszystko i będziesz mieć zainstalowany moduł MIME :: Lite na swoim komputerze. Teraz możesz wysłać wiadomość e-mail z prostymi skryptami opisanymi poniżej.
Wysyłanie zwykłej wiadomości
Poniżej znajduje się skrypt, który zajmie się wysłaniem wiadomości e-mail na podany identyfikator e-mail -
#!/usr/bin/perl
use MIME::Lite;
$to = '[email protected]'; $cc = '[email protected]';
$from = '[email protected]'; $subject = 'Test Email';
$message = 'This is test email sent by Perl Script'; $msg = MIME::Lite->new(
From => $from, To => $to,
Cc => $cc, Subject => $subject,
Data => $message ); $msg->send;
print "Email Sent Successfully\n";
Wysyłanie wiadomości HTML
Jeśli chcesz wysłać wiadomość e-mail w formacie HTML za pomocą sendmaila, wystarczy dodać Content-type: text/html\nw nagłówku wiadomości e-mail. Poniżej znajduje się skrypt, który zajmie się wysyłaniem wiadomości e-mail w formacie HTML -
#!/usr/bin/perl
use MIME::Lite;
$to = '[email protected]'; $cc = '[email protected]';
$from = '[email protected]'; $subject = 'Test Email';
$message = '<h1>This is test email sent by Perl Script</h1>'; $msg = MIME::Lite->new(
From => $from, To => $to,
Cc => $cc, Subject => $subject,
Data => $message ); $msg->attr("content-type" => "text/html");
$msg->send;
print "Email Sent Successfully\n";
Wysyłanie załącznika
Jeśli chcesz wysłać załącznik, służy do tego następujący skrypt -
#!/usr/bin/perl
use MIME::Lite;
$to = '[email protected]';
$cc = '[email protected]'; $from = '[email protected]';
$subject = 'Test Email'; $message = 'This is test email sent by Perl Script';
$msg = MIME::Lite->new( From => $from,
To => $to, Cc => $cc,
Subject => $subject, Type => 'multipart/mixed' ); # Add your text message. $msg->attach(Type => 'text',
Data => $message ); # Specify your file as attachement. $msg->attach(Type => 'image/gif',
Path => '/tmp/logo.gif',
Filename => 'logo.gif',
Disposition => 'attachment'
);
$msg->send;
print "Email Sent Successfully\n";
Możesz załączyć dowolną liczbę plików do wiadomości e-mail za pomocą metody attach ().
Korzystanie z serwera SMTP
Jeśli na Twoim komputerze nie ma serwera poczty e-mail, możesz użyć dowolnego innego serwera poczty e-mail dostępnego w lokalizacji zdalnej. Ale aby użyć dowolnego innego serwera poczty e-mail, będziesz musiał mieć identyfikator, jego hasło, adres URL itp. Gdy masz wszystkie wymagane informacje, po prostu musisz podać te informacje wsend() metoda w następujący sposób -
$msg->send('smtp', "smtp.myisp.net", AuthUser=>"id", AuthPass=>"password" );
Możesz skontaktować się z administratorem serwera e-mail, aby uzyskać powyższe informacje, a jeśli identyfikator użytkownika i hasło nie są jeszcze dostępne, administrator może je utworzyć w ciągu kilku minut.
Co to jest gniazdo?
Socket to mechanizm Berkeley UNIX służący do tworzenia wirtualnego połączenia dupleksowego między różnymi procesami. Zostało to później przeniesione na każdy znany system operacyjny, umożliwiając komunikację między systemami w różnych lokalizacjach geograficznych działającymi na różnych systemach operacyjnych. Gdyby nie gniazdo, większość komunikacji sieciowej między systemami nigdy by się nie wydarzyła.
Przyjrzyjmy się bliżej; typowy system komputerowy w sieci odbiera i wysyła informacje zgodnie z życzeniem przez różne uruchomione w nim aplikacje. Informacje te są kierowane do systemu, ponieważ jest mu przypisany unikalny adres IP. W systemie ta informacja jest przekazywana odpowiednim aplikacjom, które nasłuchują na różnych portach. Na przykład przeglądarka internetowa nasłuchuje na porcie 80 w poszukiwaniu informacji otrzymanych z serwera WWW. Możemy również napisać własne aplikacje, które mogą nasłuchiwać i wysyłać / odbierać informacje o określonym numerze portu.
Na razie podsumujmy, że gniazdo to adres IP i port, umożliwiające połączenie w celu wysyłania i odbierania danych przez sieć.
Aby wyjaśnić powyższą koncepcję gniazda, weźmiemy przykład programowania klient-serwer przy użyciu Perla. Aby ukończyć architekturę serwera klienta, musielibyśmy wykonać następujące kroki -
Aby utworzyć serwer
Utwórz gniazdo za pomocą socket połączenie.
Powiąż gniazdo z adresem portu za pomocą bind połączenie.
Nasłuchuj gniazda pod adresem portu za pomocą listen połączenie.
Zaakceptuj połączenia klientów za pomocą accept połączenie.
Aby utworzyć klienta
Utwórz gniazdo za pomocą socket połączenie.
Połącz (gniazdo) z serwerem za pomocą connect połączenie.
Poniższy diagram przedstawia pełną sekwencję wywołań używanych przez klienta i serwer do komunikacji między sobą -
Połączenia z gniazdem po stronie serwera
Wywołanie socket ()
Plik socket()wywołanie to pierwsze wywołanie podczas nawiązywania połączenia sieciowego w celu utworzenia gniazda. To wywołanie ma następującą składnię -
socket( SOCKET, DOMAIN, TYPE, PROTOCOL );
Powyższe wywołanie tworzy SOCKET, a pozostałe trzy argumenty są liczbami całkowitymi, które powinny mieć następujące wartości dla połączeń TCP / IP.
DOMAINpowinno być PF_INET. Prawdopodobnie 2 na twoim komputerze.
TYPE powinno być SOCK_STREAM dla połączenia TCP / IP.
PROTOCOL Powinien być (getprotobyname('tcp'))[2]. Jest to konkretny protokół, taki jak TCP, który ma być odczytywany przez gniazdo.
Więc wywołanie funkcji gniazda wydane przez serwer będzie wyglądało mniej więcej tak -
use Socket # This defines PF_INET and SOCK_STREAM
socket(SOCKET,PF_INET,SOCK_STREAM,(getprotobyname('tcp'))[2]);
Wywołanie bind ()
Gniazda utworzone przez wywołanie funkcji socket () są bezużyteczne, dopóki nie zostaną powiązane z nazwą hosta i numerem portu. Serwer używa następujących plikówbind() funkcji, aby określić port, na którym będą akceptować połączenia od klientów.
bind( SOCKET, ADDRESS );
Tutaj SOCKET to deskryptor zwracany przez wywołanie funkcji socket (), a ADRES to adres gniazda (dla TCP / IP) zawierający trzy elementy -
Rodzina adresów (dla TCP / IP jest to AF_INET, prawdopodobnie 2 w twoim systemie).
Numer portu (na przykład 21).
Adres internetowy komputera (na przykład 10.12.12.168).
Ponieważ bind () jest używana przez serwer, który nie musi znać własnego adresu, lista argumentów wygląda następująco -
use Socket # This defines PF_INET and SOCK_STREAM
$port = 12345; # The unique port used by the sever to listen requests $server_ip_address = "10.12.12.168";
bind( SOCKET, pack_sockaddr_in($port, inet_aton($server_ip_address)))
or die "Can't bind to port $port! \n";
Plik or die klauzula jest bardzo ważna, ponieważ jeśli serwer umrze bez zaległych połączeń, port nie będzie natychmiast ponownie używany, chyba że użyjesz opcji SO_REUSEADDR za pomocą setsockopt()funkcjonować. Tutajpack_sockaddr_in() Funkcja jest używana do pakowania portu i adresu IP w formacie binarnym.
Połączenie nasłuchu ()
Jeśli jest to program serwerowy, należy wykonać wywołanie listen()na określonym porcie, aby nasłuchiwać, tj. czekać na przychodzące żądania. To wywołanie ma następującą składnię -
listen( SOCKET, QUEUESIZE );
Powyższe wywołanie używa deskryptora SOCKET zwróconego przez wywołanie funkcji socket (), a QUEUESIZE jest maksymalną liczbą oczekujących żądań połączenia dozwolonych jednocześnie.
Wywołanie accept ()
Jeśli jest to program serwera, należy wywołać plik access()funkcja akceptowania połączeń przychodzących. To wywołanie ma następującą składnię -
accept( NEW_SOCKET, SOCKET );
Wywołanie accept odbiera deskryptor gniazda SOCKET zwrócone przez funkcję socket (), a po pomyślnym zakończeniu zwracany jest nowy deskryptor gniazda NEW_SOCKET dla całej przyszłej komunikacji między klientem a serwerem. Jeśli wywołanie access () nie powiedzie się, zwraca FLASE, który jest zdefiniowany w module Socket, którego używaliśmy na początku.
Ogólnie rzecz biorąc, accept () jest używana w nieskończonej pętli. Gdy tylko nadejdzie jedno połączenie, serwer albo tworzy proces potomny, aby sobie z nim poradzić, lub sam go obsługuje, a następnie wraca, aby nasłuchiwać kolejnych połączeń.
while(1) {
accept( NEW_SOCKET, SOCKT );
.......
}
Teraz wszystkie wywołania związane z serwerem są zakończone i zobaczmy połączenie, które będzie wymagane przez klienta.
Połączenia po stronie klienta
Połączenie connect ()
Jeśli masz zamiar przygotować program kliencki, to najpierw użyjesz socket() wywołanie, aby utworzyć gniazdo, a następnie musisz użyć connect()zadzwoń, aby połączyć się z serwerem. Widziałeś już składnię wywołania funkcji socket () i pozostanie ona podobna do wywołania funkcji socket () serwera, ale tutaj jest składniaconnect() zadzwoń -
connect( SOCKET, ADDRESS );
Tutaj SCOKET jest deskryptorem gniazda zwracanym przez wywołanie socket () wydane przez klienta, a ADRES jest adresem gniazda podobnym do wywołania bind , z tą różnicą, że zawiera adres IP zdalnego serwera.
$port = 21; # For example, the ftp port
$server_ip_address = "10.12.12.168"; connect( SOCKET, pack_sockaddr_in($port, inet_aton($server_ip_address))) or die "Can't connect to port $port! \n";
Jeśli pomyślnie połączysz się z serwerem, możesz rozpocząć wysyłanie poleceń do serwera za pomocą deskryptora SOCKET, w przeciwnym razie klient wyjdzie, podając komunikat o błędzie.
Klient - przykład serwera
Poniżej znajduje się kod Perla do implementacji prostego programu klient-serwer przy użyciu gniazda Perla. Tutaj serwer nasłuchuje nadchodzących żądań i po ustanowieniu połączenia po prostu odpowiada na Smile z serwera . Klient czyta tę wiadomość i drukuje na ekranie. Zobaczmy, jak to zostało zrobione, zakładając, że mamy nasz serwer i klienta na tej samej maszynie.
Skrypt do tworzenia serwera
#!/usr/bin/perl -w
# Filename : server.pl
use strict;
use Socket;
# use port 7890 as default
my $port = shift || 7890; my $proto = getprotobyname('tcp');
my $server = "localhost"; # Host IP running the server # create a socket, make it reusable socket(SOCKET, PF_INET, SOCK_STREAM, $proto)
or die "Can't open socket $!\n"; setsockopt(SOCKET, SOL_SOCKET, SO_REUSEADDR, 1) or die "Can't set socket option to SO_REUSEADDR $!\n";
# bind to a port, then listen
bind( SOCKET, pack_sockaddr_in($port, inet_aton($server)))
or die "Can't bind to port $port! \n"; listen(SOCKET, 5) or die "listen: $!";
print "SERVER started on port $port\n"; # accepting a connection my $client_addr;
while ($client_addr = accept(NEW_SOCKET, SOCKET)) { # send them a message, close connection my $name = gethostbyaddr($client_addr, AF_INET ); print NEW_SOCKET "Smile from the server"; print "Connection recieved from $name\n";
close NEW_SOCKET;
}
Aby uruchomić serwer w tle, wydaj następujące polecenie w monicie systemu Unix -
$perl sever.pl&
Skrypt do tworzenia klienta
!/usr/bin/perl -w
# Filename : client.pl
use strict;
use Socket;
# initialize host and port
my $host = shift || 'localhost';
my $port = shift || 7890; my $server = "localhost"; # Host IP running the server
# create the socket, connect to the port
socket(SOCKET,PF_INET,SOCK_STREAM,(getprotobyname('tcp'))[2])
or die "Can't create a socket $!\n"; connect( SOCKET, pack_sockaddr_in($port, inet_aton($server))) or die "Can't connect to port $port! \n";
my $line; while ($line = <SOCKET>) {
print "$line\n"; } close SOCKET or die "close: $!";
Teraz uruchommy naszego klienta w wierszu poleceń, który połączy się z serwerem i przeczyta wiadomość wysłaną przez serwer i wyświetli to samo na ekranie w następujący sposób -
$perl client.pl
Smile from the server
NOTE - Jeśli podajesz rzeczywisty adres IP w notacji kropkowej, zaleca się podanie adresu IP w tym samym formacie zarówno w kliencie, jak i na serwerze, aby uniknąć nieporozumień.
Przebadaliśmy już referencje w anonimowych tablicach i skrótach Perla i Perla. Koncepcja zorientowana obiektowo w Perlu opiera się w dużej mierze na odwołaniach oraz anonimowych tablicach i skrótach. Zacznijmy uczyć się podstawowych pojęć zorientowanych obiektowo w języku Perl.
Podstawy obiektów
Istnieją trzy główne terminy, wyjaśnione z punktu widzenia sposobu, w jaki Perl obsługuje obiekty. Warunki to obiekt, klasa i metoda.
Na objectw Perlu jest jedynie odniesieniem do typu danych, który wie, do jakiej klasy należy. Obiekt jest przechowywany jako odniesienie w zmiennej skalarnej. Ponieważ skalar zawiera tylko odniesienie do obiektu, ten sam skalar może zawierać różne obiekty w różnych klasach.
ZA class w Perlu jest pakiet zawierający odpowiednie metody wymagane do tworzenia obiektów i manipulowania nimi.
ZA methodw Perlu jest podprocedura zdefiniowana w pakiecie. Pierwszym argumentem metody jest odwołanie do obiektu lub nazwa pakietu, w zależności od tego, czy metoda wpływa na bieżący obiekt, czy na klasę.
Perl udostępnia bless() funkcja, która służy do zwracania odwołania, które ostatecznie staje się obiektem.
Definiowanie klasy
Definiowanie klasy w Perlu jest bardzo proste. Klasa odpowiada pakietowi Perla w jego najprostszej formie. Aby utworzyć klasę w Perlu, najpierw budujemy pakiet.
Pakiet jest samodzielną jednostką zmiennych zdefiniowanych przez użytkownika i podprogramów, których można wielokrotnie używać.
Pakiety Perla zapewniają oddzielną przestrzeń nazw w programie Perla, która utrzymuje podprogramy i zmienne niezależne od konfliktów z tymi w innych pakietach.
Aby zadeklarować klasę o nazwie Person w Perlu, robimy -
package Person;
Zakres definicji pakietu rozciąga się do końca pliku lub do momentu napotkania innego słowa kluczowego pakietu.
Tworzenie i używanie obiektów
Do stworzenia instancji klasy (obiektu) potrzebujemy konstruktora obiektów. Ten konstruktor jest metodą zdefiniowaną w pakiecie. Większość programistów decyduje się na nazwanie tej metody konstruktora obiektów nową, ale w Perlu możesz użyć dowolnej nazwy.
Możesz użyć dowolnego rodzaju zmiennej Perla jako obiektu w Perlu. Większość programistów Perla wybiera odwołania do tablic lub skrótów.
Stwórzmy nasz konstruktor dla naszej klasy Person, używając referencji skrótu Perla. Tworząc obiekt, musisz dostarczyć konstruktor, który jest procedurą wewnątrz pakietu, która zwraca odwołanie do obiektu. Odniesienie do obiektu jest tworzone przez błogosławieństwo odniesienia do klasy pakietu. Na przykład -
package Person;
sub new {
my $class = shift;
my $self = { _firstName => shift, _lastName => shift, _ssn => shift, }; # Print all the values just for clarification. print "First Name is $self->{_firstName}\n";
print "Last Name is $self->{_lastName}\n"; print "SSN is $self->{_ssn}\n";
bless $self, $class;
return $self;
}
Zobaczmy teraz, jak stworzyć obiekt.
$object = new Person( "Mohammad", "Saleem", 23234345);
Możesz użyć prostego skrótu w swoim konstruktorze, jeśli nie chcesz przypisywać żadnej wartości do żadnej zmiennej klasy. Na przykład -
package Person;
sub new {
my $class = shift; my $self = {};
bless $self, $class;
return $self;
}
Definiowanie metod
Inne języki zorientowane obiektowo mają koncepcję bezpieczeństwa danych, aby uniemożliwić programiście bezpośrednią zmianę danych obiektowych i zapewniają metody akcesorów do modyfikowania danych obiektowych. Perl nie ma zmiennych prywatnych, ale nadal możemy używać koncepcji metod pomocniczych do manipulowania danymi obiektu.
Zdefiniujmy metodę pomocniczą, aby uzyskać imię osoby -
sub getFirstName {
return $self->{_firstName};
}
Kolejna funkcja pomocnicza do ustawienia imienia osoby -
sub setFirstName {
my ( $self, $firstName ) = @_;
$self->{_firstName} = $firstName if defined($firstName); return $self->{_firstName};
}
Przyjrzyjmy się teraz kompletnemu przykładowi: Zachowaj pakiet Person i funkcje pomocnicze w pliku Person.pm.
#!/usr/bin/perl
package Person;
sub new {
my $class = shift; my $self = {
_firstName => shift,
_lastName => shift,
_ssn => shift,
};
# Print all the values just for clarification.
print "First Name is $self->{_firstName}\n"; print "Last Name is $self->{_lastName}\n";
print "SSN is $self->{_ssn}\n"; bless $self, $class; return $self;
}
sub setFirstName {
my ( $self, $firstName ) = @_;
$self->{_firstName} = $firstName if defined($firstName); return $self->{_firstName};
}
sub getFirstName {
my( $self ) = @_; return $self->{_firstName};
}
1;
Skorzystajmy teraz z obiektu Person w pliku Employer.pl w następujący sposób -
#!/usr/bin/perl
use Person;
$object = new Person( "Mohammad", "Saleem", 23234345); # Get first name which is set using constructor. $firstName = $object->getFirstName(); print "Before Setting First Name is : $firstName\n";
# Now Set first name using helper function.
$object->setFirstName( "Mohd." ); # Now get first name set by helper function. $firstName = $object->getFirstName(); print "Before Setting First Name is : $firstName\n";
Kiedy wykonujemy powyższy program, daje on następujący wynik -
First Name is Mohammad
Last Name is Saleem
SSN is 23234345
Before Setting First Name is : Mohammad
Before Setting First Name is : Mohd.
Dziedzictwo
Programowanie obiektowe ma bardzo dobrą i przydatną koncepcję zwaną dziedziczeniem. Dziedziczenie oznacza po prostu, że właściwości i metody klasy nadrzędnej będą dostępne dla klas potomnych. Nie musisz więc ciągle pisać tego samego kodu, możesz po prostu odziedziczyć klasę nadrzędną.
Na przykład możemy mieć klasę Employee, która dziedziczy po Person. Nazywa się to relacją „isa”, ponieważ pracownik to osoba. Perl ma specjalną zmienną @ISA, która pomaga w tym. @ISA zarządza dziedziczeniem (metody).
Poniżej przedstawiono ważne kwestie, które należy wziąć pod uwagę podczas korzystania z dziedziczenia -
Perl przeszukuje klasę określonego obiektu pod kątem podanej metody lub atrybutu, tj. Zmiennej.
Perl przeszukuje klasy zdefiniowane w tablicy @ISA klasy obiektów.
Jeśli żadna metoda nie zostanie znaleziona w krokach 1 lub 2, Perl używa podprogramu AUTOLOAD, jeśli znajduje się w drzewie @ISA.
Jeśli nadal nie można znaleźć pasującej metody, Perl szuka metody w klasie (pakiecie) UNIVERSAL, która jest częścią standardowej biblioteki Perla.
Jeśli metoda nadal nie została znaleziona, Perl poddaje się i zgłasza wyjątek w czasie wykonywania.
Aby utworzyć nową klasę Employee, która będzie dziedziczyć metody i atrybuty z naszej klasy Person, po prostu kodujemy w następujący sposób: Zachowaj ten kod w Employee.pm.
#!/usr/bin/perl
package Employee;
use Person;
use strict;
our @ISA = qw(Person); # inherits from Person
Teraz klasa Employee ma wszystkie metody i atrybuty odziedziczone z klasy Person i możesz ich użyć w następujący sposób: Użyj pliku main.pl do przetestowania -
#!/usr/bin/perl
use Employee;
$object = new Employee( "Mohammad", "Saleem", 23234345); # Get first name which is set using constructor. $firstName = $object->getFirstName(); print "Before Setting First Name is : $firstName\n";
# Now Set first name using helper function.
$object->setFirstName( "Mohd." ); # Now get first name set by helper function. $firstName = $object->getFirstName(); print "After Setting First Name is : $firstName\n";
Kiedy wykonujemy powyższy program, daje on następujący wynik -
First Name is Mohammad
Last Name is Saleem
SSN is 23234345
Before Setting First Name is : Mohammad
Before Setting First Name is : Mohd.
Zastępowanie metody
Klasa potomna Employee dziedziczy wszystkie metody z klasy nadrzędnej Person. Ale jeśli chcesz zastąpić te metody w swojej klasie podrzędnej, możesz to zrobić, podając własną implementację. Możesz dodać swoje dodatkowe funkcje w klasie podrzędnej lub możesz dodać lub zmodyfikować funkcjonalność istniejących metod w klasie nadrzędnej. Można to zrobić w następujący sposób: zmodyfikuj plik Employee.pm.
#!/usr/bin/perl
package Employee;
use Person;
use strict;
our @ISA = qw(Person); # inherits from Person
# Override constructor
sub new {
my ($class) = @_; # Call the constructor of the parent class, Person. my $self = $class->SUPER::new( $_[1], $_[2], $_[3] );
# Add few more attributes
$self->{_id} = undef; $self->{_title} = undef;
bless $self, $class;
return $self; } # Override helper function sub getFirstName { my( $self ) = @_;
# This is child class function.
print "This is child class helper function\n";
return $self->{_firstName}; } # Add more methods sub setLastName{ my ( $self, $lastName ) = @_; $self->{_lastName} = $lastName if defined($lastName);
return $self->{_lastName}; } sub getLastName { my( $self ) = @_;
return $self->{_lastName};
}
1;
Spróbujmy teraz ponownie użyć obiektu Employee w naszym pliku main.pl i go wykonać.
#!/usr/bin/perl
use Employee;
$object = new Employee( "Mohammad", "Saleem", 23234345);
# Get first name which is set using constructor.
$firstName = $object->getFirstName();
print "Before Setting First Name is : $firstName\n"; # Now Set first name using helper function. $object->setFirstName( "Mohd." );
# Now get first name set by helper function.
$firstName = $object->getFirstName();
print "After Setting First Name is : $firstName\n";
Kiedy wykonujemy powyższy program, daje on następujący wynik -
First Name is Mohammad
Last Name is Saleem
SSN is 23234345
This is child class helper function
Before Setting First Name is : Mohammad
This is child class helper function
After Setting First Name is : Mohd.
Domyślne automatyczne ładowanie
Perl oferuje funkcję, której nie znajdziesz w żadnym innym języku programowania: domyślny podprogram. Co oznacza, że jeśli zdefiniujesz funkcję o nazwieAUTOLOAD(),wtedy wszelkie wywołania niezdefiniowanych podprogramów automatycznie wywołają funkcję AUTOLOAD (). Nazwa brakującego podprogramu jest dostępna w tym podprogramie jako $ AUTOLOAD.
Domyślna funkcja automatycznego ładowania jest bardzo przydatna do obsługi błędów. Oto przykład implementacji AUTOLOAD, możesz zaimplementować tę funkcję na swój własny sposób.
sub AUTOLOAD {
my $self = shift; my $type = ref ($self) || croak "$self is not an object";
my $field = $AUTOLOAD;
$field =~ s/.*://; unless (exists $self->{$field}) { croak "$field does not exist in object/class $type"; } if (@_) { return $self->($name) = shift; } else { return $self->($name);
}
}
Destruktory i odśmiecanie
Jeśli wcześniej programowałeś przy użyciu programowania obiektowego, będziesz świadomy potrzeby utworzenia pliku destructoraby zwolnić pamięć przydzieloną obiektowi po zakończeniu korzystania z niego. Perl robi to automatycznie, gdy tylko obiekt znajdzie się poza zasięgiem.
Jeśli chcesz zaimplementować Twój destruktor, który powinien zająć się zamykaniem plików lub wykonywaniem dodatkowego przetwarzania, musisz zdefiniować specjalną metodę o nazwie DESTROY. Ta metoda zostanie wywołana na obiekcie tuż przed zwolnieniem przez Perl przydzielonej mu pamięci. Pod każdym innym względem metoda DESTROY jest taka sama, jak każda inna metoda i możesz zaimplementować dowolną logikę w tej metodzie.
Metoda destruktora to po prostu funkcja składowa (podprocedura) o nazwie DESTROY, która zostanie wywołana automatycznie w następujących przypadkach:
- Gdy zmienna odwołania do obiektu wykracza poza zakres.
- Gdy zmienna odniesienia do obiektu jest niezdefiniowana.
- Kiedy skrypt się kończy
- Kiedy interpreter perla kończy działanie
Na przykład możesz po prostu umieścić następującą metodę DESTROY w swojej klasie -
package MyClass;
...
sub DESTROY {
print "MyClass::DESTROY called\n";
}
Przykład języka Perl zorientowany obiektowo
Oto kolejny fajny przykład, który pomoże ci zrozumieć koncepcje zorientowane obiektowo w Perlu. Umieść ten kod źródłowy w dowolnym pliku Perla i uruchom go.
#!/usr/bin/perl
# Following is the implementation of simple Class.
package MyClass;
sub new {
print "MyClass::new called\n";
my $type = shift; # The package/type name
my $self = {}; # Reference to empty hash return bless $self, $type; } sub DESTROY { print "MyClass::DESTROY called\n"; } sub MyMethod { print "MyClass::MyMethod called!\n"; } # Following is the implemnetation of Inheritance. package MySubClass; @ISA = qw( MyClass ); sub new { print "MySubClass::new called\n"; my $type = shift; # The package/type name
my $self = MyClass->new; # Reference to empty hash return bless $self, $type; } sub DESTROY { print "MySubClass::DESTROY called\n"; } sub MyMethod { my $self = shift;
$self->SUPER::MyMethod(); print " MySubClass::MyMethod called!\n"; } # Here is the main program using above classes. package main; print "Invoke MyClass method\n"; $myObject = MyClass->new();
$myObject->MyMethod(); print "Invoke MySubClass method\n"; $myObject2 = MySubClass->new();
$myObject2->MyMethod(); print "Create a scoped object\n"; { my $myObject2 = MyClass->new();
}
# Destructor is called automatically here
print "Create and undef an object\n";
$myObject3 = MyClass->new(); undef $myObject3;
print "Fall off the end of the script...\n";
# Remaining destructors are called automatically here
Kiedy wykonujemy powyższy program, daje on następujący wynik -
Invoke MyClass method
MyClass::new called
MyClass::MyMethod called!
Invoke MySubClass method
MySubClass::new called
MyClass::new called
MyClass::MyMethod called!
MySubClass::MyMethod called!
Create a scoped object
MyClass::new called
MyClass::DESTROY called
Create and undef an object
MyClass::new called
MyClass::DESTROY called
Fall off the end of the script...
MyClass::DESTROY called
MySubClass::DESTROY called
W tym rozdziale dowiesz się, jak uzyskać dostęp do bazy danych w skrypcie Perl. Począwszy od Perla 5, pisanie aplikacji bazodanowych przy użyciuDBImoduł. DBI oznaczaDatabase Independent Interface dla Perla, co oznacza, że DBI zapewnia warstwę abstrakcji między kodem Perla a bazową bazą danych, umożliwiając naprawdę łatwe przełączanie implementacji bazy danych.
DBI to moduł dostępu do bazy danych dla języka programowania Perl. Udostępnia zestaw metod, zmiennych i konwencji, które zapewniają spójny interfejs bazy danych, niezależny od aktualnie używanej bazy danych.
Architektura aplikacji DBI
DBI jest niezależne od jakiejkolwiek bazy danych dostępnej na zapleczu. Możesz używać DBI niezależnie od tego, czy pracujesz z Oracle, MySQL czy Informix, itp. Wynika to jasno z poniższego diagramu architektury.
W tym przypadku DBI jest odpowiedzialny za przejęcie wszystkich poleceń SQL przez API (tj. Interfejs programowania aplikacji) i wysłanie ich do odpowiedniego sterownika w celu rzeczywistego wykonania. I wreszcie DBI jest odpowiedzialny za pobranie wyników od sterownika i przekazanie ich wywołującemu scritpowi.
Notacja i konwencje
W całym rozdziale będą używane następujące oznaczenia i zaleca się, abyś również przestrzegał tej samej konwencji.
$dsn Database source name $dbh Database handle object
$sth Statement handle object $h Any of the handle types above ($dbh, $sth, or $drh) $rc General Return Code (boolean: true=ok, false=error)
$rv General Return Value (typically an integer) @ary List of values returned from the database. $rows Number of rows processed (if available, else -1)
$fh A filehandle
undef NULL values are represented by undefined values in Perl
\%attr Reference to a hash of attribute values passed to methods
Połączenie z bazą danych
Zakładając, że będziemy pracować z bazą danych MySQL. Przed połączeniem się z bazą danych upewnij się, że są spełnione następujące warunki. Możesz skorzystać z naszego samouczka MySQL, jeśli nie wiesz, jak utworzyć bazę danych i tabele w bazie danych MySQL.
Utworzyłeś bazę danych o nazwie TESTDB.
Utworzyłeś tabelę o nazwie TEST_TABLE w TESTDB.
Ta tabela zawiera pola FIRST_NAME, LAST_NAME, AGE, SEX i INCOME.
ID użytkownika „testuser” i hasło „test123” są ustawione na dostęp do bazy danych TESTDB.
Perl Module DBI jest poprawnie zainstalowany na twoim komputerze.
Przeszedłeś przez samouczek MySQL, aby zrozumieć podstawy MySQL.
Poniżej przykład połączenia z bazą danych MySQL „TESTDB” -
#!/usr/bin/perl
use DBI
use strict;
my $driver = "mysql";
my $database = "TESTDB"; my $dsn = "DBI:$driver:database=$database";
my $userid = "testuser"; my $password = "test123";
my $dbh = DBI->connect($dsn, $userid, $password ) or die $DBI::errstr;
Jeśli połączenie zostanie nawiązane ze źródłem danych, zwracany jest uchwyt bazy danych i zapisywany w $ dbh do dalszego użytku, w przeciwnym razie $ dbh jest ustawiana na wartość undef, a $ DBI :: errstr zwraca łańcuch błędu.
Operacja INSERT
Operacja INSERT jest wymagana, gdy chcesz utworzyć niektóre rekordy w tabeli. Tutaj używamy tabeli TEST_TABLE do tworzenia naszych rekordów. Więc po nawiązaniu połączenia z bazą danych jesteśmy gotowi do tworzenia rekordów w TEST_TABLE. Poniżej znajduje się procedura tworzenia pojedynczego rekordu w TEST_TABLE. Możesz utworzyć dowolną liczbę rekordów, używając tej samej koncepcji.
Tworzenie rekordu obejmuje następujące kroki -
Przygotowanie instrukcji SQL z instrukcją INSERT. Zostanie to zrobione za pomocąprepare() API.
Wykonywanie zapytania SQL w celu wybrania wszystkich wyników z bazy danych. Zostanie to zrobione za pomocąexecute() API.
Zwalniam uchwyt Stattement. Zostanie to zrobione za pomocąfinish() API.
Jeśli wszystko pójdzie dobrze commit ta operacja inaczej możesz rollbackzakończyć transakcję. Commit i Rollback są wyjaśnione w następnych sekcjach.
my $sth = $dbh->prepare("INSERT INTO TEST_TABLE
(FIRST_NAME, LAST_NAME, SEX, AGE, INCOME )
values
('john', 'poul', 'M', 30, 13000)");
$sth->execute() or die $DBI::errstr;
$sth->finish(); $dbh->commit or die $DBI::errstr;
Korzystanie z wartości powiązań
Może się zdarzyć, że wartości do wprowadzenia nie zostaną podane z góry. Możesz więc używać zmiennych wiążących, które przyjmą wymagane wartości w czasie wykonywania. Moduły Perl DBI używają znaku zapytania zamiast rzeczywistej wartości, a następnie rzeczywiste wartości są przekazywane przez funkcję API execute () w czasie wykonywania. Oto przykład -
my $first_name = "john";
my $last_name = "poul"; my $sex = "M";
my $income = 13000; my $age = 30;
my $sth = $dbh->prepare("INSERT INTO TEST_TABLE
(FIRST_NAME, LAST_NAME, SEX, AGE, INCOME )
values
(?,?,?,?)");
$sth->execute($first_name,$last_name,$sex, $age, $income)
or die $DBI::errstr; $sth->finish();
$dbh->commit or die $DBI::errstr;
Operacja READ
READ Operacja na dowolnej bazie danych oznacza pobranie przydatnych informacji z bazy danych, tj. Jednego lub więcej rekordów z jednej lub więcej tabel. Więc po nawiązaniu połączenia z bazą danych jesteśmy gotowi do wysłania zapytania do tej bazy danych. Poniżej przedstawiono procedurę odpytywania wszystkich rekordów o WIEKU większym niż 20. To zajmie cztery kroki -
Przygotowanie zapytania SQL SELECT na podstawie wymaganych warunków. Zostanie to zrobione za pomocąprepare() API.
Wykonywanie zapytania SQL w celu wybrania wszystkich wyników z bazy danych. Zostanie to zrobione za pomocąexecute() API.
Pobieranie wszystkich wyników jeden po drugim i drukowanie ich za pomocą fetchrow_array() API.
Zwalniam uchwyt Stattement. Zostanie to zrobione za pomocąfinish() API.
my $sth = $dbh->prepare("SELECT FIRST_NAME, LAST_NAME
FROM TEST_TABLE
WHERE AGE > 20");
$sth->execute() or die $DBI::errstr;
print "Number of rows found :" + $sth->rows; while (my @row = $sth->fetchrow_array()) {
my ($first_name, $last_name ) = @row;
print "First Name = $first_name, Last Name = $last_name\n";
}
$sth->finish();
Korzystanie z wartości powiązań
Może się zdarzyć, że warunek nie zostanie podany z góry. Możesz więc używać zmiennych wiążących, które przyjmą wymagane wartości w czasie wykonywania. Moduły Perl DBI używają znaku zapytania zamiast rzeczywistej wartości, a następnie rzeczywiste wartości są przekazywane przez funkcję API execute () w czasie wykonywania. Oto przykład -
$age = 20;
my $sth = $dbh->prepare("SELECT FIRST_NAME, LAST_NAME
FROM TEST_TABLE
WHERE AGE > ?");
$sth->execute( $age ) or die $DBI::errstr; print "Number of rows found :" + $sth->rows;
while (my @row = $sth->fetchrow_array()) { my ($first_name, $last_name ) = @row; print "First Name = $first_name, Last Name = $last_name\n"; } $sth->finish();
Operacja UPDATE
UPDATE Operacja na dowolnej bazie danych oznacza aktualizację jednego lub więcej rekordów już dostępnych w tabelach bazy danych. Poniżej przedstawiono procedurę aktualizacji wszystkich rekordów, które mają PŁEĆ jako „M”. Tutaj zwiększymy WIEK wszystkich samców o jeden rok. To zajmie trzy kroki -
Przygotowanie zapytania SQL na podstawie wymaganych warunków. Zostanie to zrobione za pomocąprepare() API.
Wykonywanie zapytania SQL w celu wybrania wszystkich wyników z bazy danych. Zostanie to zrobione za pomocąexecute() API.
Zwalniam uchwyt Stattement. Zostanie to zrobione za pomocąfinish() API.
Jeśli wszystko pójdzie dobrze commit ta operacja inaczej możesz rollbackzakończyć transakcję. Zobacz następną sekcję dotyczącą interfejsów API zatwierdzania i wycofywania.
my $sth = $dbh->prepare("UPDATE TEST_TABLE
SET AGE = AGE + 1
WHERE SEX = 'M'");
$sth->execute() or die $DBI::errstr;
print "Number of rows updated :" + $sth->rows; $sth->finish();
$dbh->commit or die $DBI::errstr;
Korzystanie z wartości powiązań
Może się zdarzyć, że warunek nie zostanie podany z góry. Możesz więc używać zmiennych wiążących, które przyjmą wymagane wartości w czasie wykonywania. Moduły Perl DBI używają znaku zapytania zamiast rzeczywistej wartości, a następnie rzeczywiste wartości są przekazywane przez funkcję API execute () w czasie wykonywania. Oto przykład -
$sex = 'M'; my $sth = $dbh->prepare("UPDATE TEST_TABLE SET AGE = AGE + 1 WHERE SEX = ?"); $sth->execute('$sex') or die $DBI::errstr;
print "Number of rows updated :" + $sth->rows; $sth->finish();
$dbh->commit or die $DBI::errstr;
W niektórych przypadkach chcesz ustawić wartość, która nie jest podana z góry, więc możesz użyć wartości wiążącej w następujący sposób. W tym przykładzie dochód wszystkich mężczyzn wyniesie 10000.
$sex = 'M'; $income = 10000;
my $sth = $dbh->prepare("UPDATE TEST_TABLE
SET INCOME = ?
WHERE SEX = ?");
$sth->execute( $income, '$sex') or die $DBI::errstr;
print "Number of rows updated :" + $sth->rows; $sth->finish();
Operacja USUŃ
Operacja DELETE jest wymagana, gdy chcesz usunąć niektóre rekordy z bazy danych. Poniżej przedstawiono procedurę usuwania wszystkich rekordów z TEST_TABLE, gdzie AGE jest równe 30. Ta operacja obejmuje następujące kroki.
Przygotowanie zapytania SQL na podstawie wymaganych warunków. Zostanie to zrobione za pomocąprepare() API.
Wykonywanie zapytania SQL w celu usunięcia wymaganych rekordów z bazy danych. Zostanie to zrobione za pomocąexecute() API.
Zwalniam uchwyt Stattement. Zostanie to zrobione za pomocąfinish() API.
Jeśli wszystko pójdzie dobrze commit ta operacja inaczej możesz rollback zakończyć transakcję.
$age = 30; my $sth = $dbh->prepare("DELETE FROM TEST_TABLE WHERE AGE = ?"); $sth->execute( $age ) or die $DBI::errstr;
print "Number of rows deleted :" + $sth->rows; $sth->finish();
$dbh->commit or die $DBI::errstr;
Korzystanie z instrukcji do
Jeśli wykonujesz AKTUALIZACJĘ, WSTAW lub USUŃ, nie ma danych, które wrócą z bazy danych, więc istnieje skrót do wykonania tej operacji. Możesz użyćdo instrukcja, aby wykonać dowolne z następujących poleceń.
$dbh->do('DELETE FROM TEST_TABLE WHERE age =30');
dozwraca wartość true, jeśli się powiedzie, i wartość false, jeśli się nie powiedzie. W rzeczywistości, jeśli się powiedzie, zwraca liczbę wierszy, których to dotyczy. W tym przykładzie zwróci liczbę wierszy, które zostały faktycznie usunięte.
Operacja COMMIT
Commit to operacja, która daje zielony sygnał do bazy danych w celu sfinalizowania zmian i po tej operacji żadna zmiana nie może zostać przywrócona do pierwotnej pozycji.
Oto prosty przykład do zadzwonienia commit API.
$dbh->commit or die $dbh->errstr;
Operacja ROLLBACK
Jeśli nie jesteś zadowolony ze wszystkich zmian lub napotkasz błąd między jakąkolwiek operacją, możesz przywrócić te zmiany do użycia rollback API.
Oto prosty przykład do zadzwonienia rollback API.
$dbh->rollback or die $dbh->errstr;
Rozpocznij transakcję
Wiele baz danych obsługuje transakcje. Oznacza to, że możesz wykonać całą masę zapytań, które zmodyfikowałyby bazy danych, ale żadna ze zmian nie jest faktycznie wprowadzana. Następnie na koniec wysyłasz specjalne zapytanie SQLCOMMIT, a wszystkie zmiany są wprowadzane jednocześnie. Alternatywnie możesz wysłać zapytanie ROLLBACK, w którym to przypadku wszystkie zmiany zostaną odrzucone, a baza danych pozostanie niezmieniona.
Dostarczony moduł Perl DBI begin_workAPI, który umożliwia transakcje (poprzez wyłączenie AutoCommit) do następnego wywołania zatwierdzenia lub wycofania. Po następnym zatwierdzeniu lub wycofaniu AutoCommit zostanie automatycznie ponownie włączony.
$rc = $dbh->begin_work or die $dbh->errstr;
Opcja AutoCommit
Jeśli Twoje transakcje są proste, możesz zaoszczędzić sobie kłopotów z koniecznością wystawiania wielu zatwierdzeń. Podczas nawiązywania połączenia możesz określićAutoCommitopcja, która wykona operację automatycznego zatwierdzenia po każdym pomyślnym zapytaniu. Oto, jak to wygląda -
my $dbh = DBI->connect($dsn, $userid, $password,
{AutoCommit => 1})
or die $DBI::errstr;
Tutaj AutoCommit może przyjąć wartość 1 lub 0, gdzie 1 oznacza AutoCommit jest włączone, a 0 oznacza AutoCommit jest wyłączone.
Automatyczna obsługa błędów
Podczas wykonywania połączenia connect można określić opcję RaiseErrors, która automatycznie obsługuje błędy. Gdy wystąpi błąd, DBI przerwie twój program zamiast zwrócić kod błędu. Jeśli chcesz tylko przerwać program z powodu błędu, może to być wygodne. Oto, jak to wygląda -
my $dbh = DBI->connect($dsn, $userid, $password, {RaiseError => 1}) or die $DBI::errstr;
Tutaj RaiseError może przyjąć wartość 1 lub 0.
Odłączanie bazy danych
Aby rozłączyć połączenie z bazą danych, użyj disconnect API w następujący sposób -
$rc = $dbh->disconnect or warn $dbh->errstr;
Zachowanie transakcyjne metody rozłączenia jest niestety nieokreślone. Niektóre systemy baz danych (takie jak Oracle i Ingres) automatycznie zatwierdzą wszelkie zaległe zmiany, ale inne (takie jak Informix) wycofają wszelkie zaległe zmiany. Aplikacje, które nie używają AutoCommit, powinny jawnie wywoływać zatwierdzanie lub wycofywanie przed wywołaniem rozłączenia.
Korzystanie z wartości NULL
Niezdefiniowane wartości lub undef są używane do wskazywania wartości NULL. Możesz wstawiać i aktualizować kolumny o wartości NULL, tak jak w przypadku wartości innej niż NULL. Te przykłady wstawiają i aktualizują wiek kolumny o wartość NULL -
$sth = $dbh->prepare(qq { INSERT INTO TEST_TABLE (FIRST_NAME, AGE) VALUES (?, ?) }); $sth->execute("Joe", undef);
Tutaj qq{} służy do zwracania ciągu znaków w cudzysłowie prepareAPI. Należy jednak zachować ostrożność, próbując użyć wartości NULL w klauzuli WHERE. Rozważ -
SELECT FIRST_NAME FROM TEST_TABLE WHERE age = ?
Powiązanie undef (NULL) z symbolem zastępczym nie spowoduje wybrania wierszy, które mają NULL wiek! Przynajmniej dla silników baz danych zgodnych ze standardem SQL. Zapoznaj się z instrukcją SQL silnika bazy danych lub dowolną książką SQL, aby dowiedzieć się, dlaczego tak jest. Aby jawnie wybrać wartości NULL, musisz powiedzieć „WHERE age IS NULL”.
Częstym problemem jest to, że fragment kodu obsługuje wartość, która może być zdefiniowana lub undef (inna niż NULL lub NULL) w czasie wykonywania. Prostą techniką jest przygotowanie odpowiedniej instrukcji w razie potrzeby i zastąpienie symbolu zastępczego dla przypadków innych niż NULL -
$sql_clause = defined $age? "age = ?" : "age IS NULL";
$sth = $dbh->prepare(qq {
SELECT FIRST_NAME FROM TEST_TABLE WHERE $sql_clause }); $sth->execute(defined $age ? $age : ());
Niektóre inne funkcje DBI
available_drivers
@ary = DBI->available_drivers;
@ary = DBI->available_drivers($quiet);
Zwraca listę wszystkich dostępnych sterowników, wyszukując moduły DBD :: * w katalogach w @INC. Domyślnie wyświetlane jest ostrzeżenie, jeśli niektóre sterowniki są ukryte przez inne o tej samej nazwie we wcześniejszych katalogach. Przekazanie wartości true dla $ quiet wstrzyma ostrzeżenie.
zainstalowane_ sterowniki
%drivers = DBI->installed_drivers();
Zwraca listę nazw sterowników i par uchwytów sterowników dla wszystkich „zainstalowanych” (załadowanych) sterowników w bieżącym procesie. Nazwa sterownika nie zawiera przedrostka „DBD ::”.
źródła danych
@ary = DBI->data_sources($driver);
Zwraca listę źródeł danych (baz danych) dostępnych za pośrednictwem nazwanego sterownika. Jeśli $ driver jest pusty lub undef, to używana jest wartość zmiennej środowiskowej DBI_DRIVER.
zacytować
$sql = $dbh->quote($value); $sql = $dbh->quote($value, $data_type);
Cytuj literał ciągu, aby użyć go jako wartości literału w instrukcji SQL, unikając znaków specjalnych (takich jak cudzysłowy) zawartych w ciągu i dodając wymagany typ zewnętrznych cudzysłowów.
$sql = sprintf "SELECT foo FROM bar WHERE baz = %s",
$dbh->quote("Don't");
W przypadku większości typów baz danych cudzysłów zwróciłby „Don''t” (łącznie z zewnętrznymi cudzysłowami). Metoda quote () może zwracać wyrażenie SQL, którego wynikiem jest żądany ciąg. Na przykład -
$quoted = $dbh->quote("one\ntwo\0three")
may produce results which will be equivalent to
CONCAT('one', CHAR(12), 'two', CHAR(0), 'three')
Metody wspólne dla wszystkich uchwytów
błądzić
$rv = $h->err; or $rv = $DBI::err or $rv = $h->err
Zwraca kod błędu natywnego silnika bazy danych z ostatniej wywołanej metody sterownika. Kod jest zazwyczaj liczbą całkowitą, ale nie należy tego zakładać. Jest to odpowiednik $ DBI :: err lub $ h-> err.
errstr
$str = $h->errstr; or $str = $DBI::errstr or $str = $h->errstr
Zwraca komunikat o błędzie rodzimego silnika bazy danych z ostatniej wywołanej metody DBI. Ma to te same problemy z trwałością, co metoda „err” opisana powyżej. Jest to odpowiednik $ DBI :: errstr lub $ h-> errstr.
wydziwianie
$rv = $h->rows; or $rv = $DBI::rows
Zwraca liczbę wierszy wykonanych przez poprzednią instrukcję SQL i równoważną $ DBI :: rows.
ślad
$h->trace($trace_settings);
DBI posiada niezwykle przydatną zdolność do generowania informacji o tym, co robi w czasie wykonywania, co może być ogromną oszczędnością czasu, gdy próbuje się znaleźć dziwne problemy w programach DBI. Możesz użyć różnych wartości, aby ustawić poziom śledzenia. Wartości te wahają się od 0 do 4. Wartość 0 oznacza wyłączenie śledzenia, a 4 oznacza generowanie pełnego śledzenia.
Zabronione są stwierdzenia interpolowane
Zdecydowanie zaleca się, aby nie używać następujących interpolowanych instrukcji -
while ($first_name = <>) { my $sth = $dbh->prepare("SELECT * FROM TEST_TABLE WHERE FIRST_NAME = '$first_name'");
$sth->execute();
# and so on ...
}
Dlatego nie używaj interpolowanej instrukcji, zamiast tego użyj bind value przygotowanie dynamicznych instrukcji SQL.
Co to jest CGI?
Common Gateway Interface (CGI) to zestaw standardów definiujących sposób wymiany informacji między serwerem WWW a niestandardowym skryptem.
Specyfikacje CGI są obecnie utrzymywane przez NCSA, a NCSA definiuje CGI w następujący sposób:
Interfejs Common Gateway Interface (CGI) jest standardem dla zewnętrznych programów bram do łączenia się z serwerami informacyjnymi, takimi jak serwery HTTP.
Obecna wersja to CGI / 1.1, a CGI / 1.2 jest w trakcie opracowywania.
Przeglądanie sieci
Aby zrozumieć koncepcję CGI, zobaczmy, co się dzieje, gdy klikamy hiperłącze dostępne na stronie internetowej, aby przeglądać określoną stronę internetową lub adres URL.
Twoja przeglądarka kontaktuje się z serwerem WWW przy użyciu protokołu HTTP i żąda adresu URL, tj. Nazwy pliku strony internetowej.
Serwer WWW sprawdzi adres URL i poszuka żądanej nazwy pliku. Jeśli serwer sieciowy znajdzie ten plik, wysyła go z powrotem do przeglądarki bez dalszego wykonywania, w przeciwnym razie wysyła komunikat o błędzie wskazujący, że zażądałeś niewłaściwego pliku.
Przeglądarka internetowa pobiera odpowiedź z serwera WWW i wyświetla treść odebranego pliku lub komunikat o błędzie w przypadku, gdy plik nie zostanie znaleziony.
Istnieje jednak możliwość skonfigurowania serwera HTTP w taki sposób, aby za każdym razem, gdy zażądano pliku w określonym katalogu, plik ten nie był odsyłany; zamiast tego jest wykonywany jako program i cokolwiek ten program wyprowadza w wyniku, jest wysyłane z powrotem do przeglądarki do wyświetlenia. Można to zrobić za pomocą specjalnej funkcjonalności dostępnej na serwerze WWW i nazywa sięCommon Gateway Interfacelub CGI i takie programy, które są wykonywane przez serwer w celu uzyskania wyniku końcowego, nazywane są skryptami CGI. Te programy CGI mogą być skryptami PERL, skryptami powłoki, programami w języku C lub C ++ itp.
Diagram architektury CGI
Obsługa i konfiguracja serwera WWW
Przed przystąpieniem do programowania CGI upewnij się, że serwer WWW obsługuje funkcje CGI i jest skonfigurowany do obsługi programów CGI. Wszystkie programy CGI, które mają być wykonywane przez serwer sieciowy, są przechowywane we wstępnie skonfigurowanym katalogu. Ten katalog nazywa się katalogiem CGI i zgodnie z konwencją nosi nazwę / cgi-bin. Zgodnie z konwencją pliki Perl CGI będą miały rozszerzenie jako.cgi.
Pierwszy program CGI
Oto prosty odsyłacz do skryptu CGI o nazwie hello.cgi . Ten plik został zachowany/cgi-bin/katalogu i ma następującą zawartość. Przed uruchomieniem programu CGI upewnij się, że masz zmianę trybu pliku za pomocąchmod 755 hello.cgi Polecenie UNIX.
#!/usr/bin/perl
print "Content-type:text/html\r\n\r\n";
print '<html>';
print '<head>';
print '<title>Hello Word - First CGI Program</title>';
print '</head>';
print '<body>';
print '<h2>Hello Word! This is my first CGI program</h2>';
print '</body>';
print '</html>';
1;
Teraz, jeśli klikniesz hello.cgi link następnie żądanie trafia do serwera WWW, który wyszukuje hello.cgi w katalogu / cgi-bin, wykonuje go i niezależnie od wygenerowanego wyniku, serwer sieciowy wysyła ten wynik z powrotem do przeglądarki internetowej, co jest następujące -
Hello Word! This is my first CGI program
Ten skrypt hello.cgi jest prostym skryptem Perla, który zapisuje swoje dane wyjściowe do pliku STDOUT, tj. Screen. Dostępna jest jedna ważna i dodatkowa funkcja, czyli pierwsza linia do wydrukowaniaContent-type:text/html\r\n\r\n. Ta linia jest wysyłana z powrotem do przeglądarki i określa typ zawartości, która ma być wyświetlana na ekranie przeglądarki. Teraz musisz znać podstawową koncepcję CGI i możesz napisać wiele skomplikowanych programów CGI używając Perla. Ten skrypt może współdziałać z dowolnym innym systemem zewnętrznym, także w celu wymiany informacji, takich jak baza danych, usługi sieciowe lub inne złożone interfejsy.
Zrozumienie nagłówka HTTP
Pierwsza linia Content-type:text/html\r\n\r\nto część nagłówka HTTP, która jest wysyłana do przeglądarki, aby przeglądarka mogła odczytać zawartość przychodzącą od strony serwera. Cały nagłówek HTTP będzie miał następującą postać -
HTTP Field Name: Field Content
Na przykład -
Content-type:text/html\r\n\r\n
Istnieje kilka innych ważnych nagłówków HTTP, których będziesz często używać w programowaniu CGI.
Sr.No. | Nagłówek i opis |
---|---|
1 | Content-type: String Ciąg MIME definiujący format zwracanej treści. Przykład: Typ treści: tekst / html |
2 | Expires: Date String Data, w której informacje stają się nieważne. Powinno to być używane przez przeglądarkę, aby zdecydować, kiedy strona wymaga odświeżenia. Prawidłowy ciąg daty powinien mieć format 01 Jan 1998 12:00:00 GMT. |
3 | Location: URL String Adres URL, który powinien zostać zwrócony zamiast żądanego adresu URL. Możesz użyć tego pola, aby przekierować żądanie do dowolnej innej lokalizacji. |
4 | Last-modified: String Data ostatniej modyfikacji pliku. |
5 | Content-length: String Długość zwracanych danych w bajtach. Przeglądarka używa tej wartości do raportowania szacowanego czasu pobierania pliku. |
6 | Set-Cookie: String Ustaw plik cookie przekazany przez ciąg |
Zmienne środowiskowe CGI
Cały program CGI będzie miał dostęp do następujących zmiennych środowiskowych. Te zmienne odgrywają ważną rolę podczas pisania dowolnego programu CGI.
Sr.No. | Nazwy i opis zmiennych |
---|---|
1 | CONTENT_TYPE Typ danych treści. Używane, gdy klient wysyła załączoną zawartość na serwer. Na przykład przesyłanie plików itp. |
2 | CONTENT_LENGTH Długość informacji o zapytaniu. Jest dostępny tylko dla żądań POST |
3 | HTTP_COOKIE Zwraca ustawione pliki cookie w postaci pary klucz-wartość. |
4 | HTTP_USER_AGENT Pole nagłówka żądania agenta użytkownika zawiera informacje o kliencie użytkownika, który wysłał żądanie. Nazwa przeglądarki internetowej. |
5 | PATH_INFO Ścieżka do skryptu CGI. |
6 | QUERY_STRING Informacje zakodowane w adresie URL, które są wysyłane z żądaniem metody GET. |
7 | REMOTE_ADDR Adres IP zdalnego hosta wysyłającego żądanie. Może to być przydatne do logowania lub do celów uwierzytelniania. |
8 | REMOTE_HOST W pełni kwalifikowana nazwa hosta wysyłającego żądanie. Jeśli te informacje nie są dostępne, można użyć REMOTE_ADDR do uzyskania adresu IR. |
9 | REQUEST_METHOD Metoda użyta do wysłania żądania. Najpopularniejsze metody to GET i POST. |
10 | SCRIPT_FILENAME Pełna ścieżka do skryptu CGI. |
11 | SCRIPT_NAME Nazwa skryptu CGI. |
12 | SERVER_NAME Nazwa hosta lub adres IP serwera. |
13 | SERVER_SOFTWARE Nazwa i wersja oprogramowania, na którym działa serwer. |
Oto mały program CGI, który wyświetla listę wszystkich zmiennych CGI obsługiwanych przez serwer WWW. Kliknij to łącze, aby zobaczyć wynik Pobierz środowisko
#!/usr/bin/perl
print "Content-type: text/html\n\n";
print "<font size=+1>Environment</font>\n";
foreach (sort keys %ENV) {
print "<b>$_</b>: $ENV{$_}<br>\n";
}
1;
Czy otworzyć okno dialogowe „Pobieranie pliku”?
Czasami pożądane jest udostępnienie opcji, w której użytkownik kliknie łącze, a zamiast wyświetlania rzeczywistej zawartości wyświetli się okno dialogowe „Pobieranie pliku”. Jest to bardzo łatwe i można je uzyskać poprzez nagłówek HTTP.
Ten nagłówek HTTP będzie inny niż nagłówek wspomniany w poprzedniej sekcji. Na przykład, jeśli chcesz utworzyć plikFileName plik do pobrania z podanego linku to jego składnia będzie następująca -
#!/usr/bin/perl
# HTTP Header
print "Content-Type:application/octet-stream; name = \"FileName\"\r\n";
print "Content-Disposition: attachment; filename = \"FileName\"\r\n\n";
# Actual File Content will go hear.
open( FILE, "<FileName" );
while(read(FILE, $buffer, 100) ) { print("$buffer");
}
Metody GET i POST
Musiałeś spotkać się z wieloma sytuacjami, kiedy musisz przekazać pewne informacje z przeglądarki na serwer WWW, a ostatecznie do programu CGI obsługującego twoje żądania. Przeglądarka najczęściej korzysta z dwóch metod przekazywania tych informacji do serwera WWW. Te metody sąGET Metoda i POSTMetoda. Sprawdźmy je jeden po drugim.
Przekazywanie informacji metodą GET
Metoda GET wysyła zakodowane informacje o użytkowniku dołączone do samego adresu URL strony. Strona i zakodowane informacje są oddzielone znakiem? znak w następujący sposób -
http://www.test.com/cgi-bin/hello.cgi?key1=value1&key2=value2
Metoda GET jest domyślną metodą przekazywania informacji z przeglądarki do serwera WWW i tworzy długi ciąg znaków, który pojawia się w polu Lokalizacja: przeglądarki. Nigdy nie powinieneś używać metody GET, jeśli masz hasło lub inne poufne informacje do przekazania do serwera. Metoda GET ma ograniczenie rozmiaru: w ciągu żądania można przekazać tylko 1024 znaki.
Ta informacja jest przekazywana za pomocą QUERY_STRING nagłówka i będzie dostępny w programie CGI poprzez zmienną środowiskową QUERY_STRING, którą można analizować i używać w programie CGI.
Możesz przekazywać informacje, po prostu łącząc pary klucz i wartość wraz z dowolnym adresem URL lub możesz użyć tagów HTML <FORM>, aby przekazać informacje metodą GET.
Prosty przykład adresu URL: metoda pobierania
Oto prosty adres URL, który przekazuje dwie wartości do programu hello_get.cgi przy użyciu metody GET.
http://www.tutorialspoint.com/cgi-bin/hello_get.cgi?first_name=ZARA&last_name=ALIPoniżej jest hello_get.cgi skrypt do obsługi danych wejściowych podawanych przez przeglądarkę internetową.
#!/usr/bin/perl
local ($buffer, @pairs, $pair, $name, $value, %FORM);
# Read in text
$ENV{'REQUEST_METHOD'} =~ tr/a-z/A-Z/; if ($ENV{'REQUEST_METHOD'} eq "GET") {
$buffer = $ENV{'QUERY_STRING'};
}
# Split information into name/value pairs
@pairs = split(/&/, $buffer); foreach $pair (@pairs) {
($name, $value) = split(/=/, $pair); $value =~ tr/+/ /;
$value =~ s/%(..)/pack("C", hex($1))/eg;
$FORM{$name} = $value; } $first_name = $FORM{first_name}; $last_name = $FORM{last_name}; print "Content-type:text/html\r\n\r\n"; print "<html>"; print "<head>"; print "<title>Hello - Second CGI Program</title>"; print "</head>"; print "<body>"; print "<h2>Hello $first_name $last_name - Second CGI Program</h2>";
print "</body>";
print "</html>";
1;
Prosty przykład FORMULARZA: GET Method
Oto prosty przykład, który przekazuje dwie wartości za pomocą HTML FORM i przycisku przesyłania. Zamierzamy użyć tego samego skryptu CGI hello_get.cgi do obsługi tego wejścia.
<FORM action = "/cgi-bin/hello_get.cgi" method = "GET">
First Name: <input type = "text" name = "first_name"> <br>
Last Name: <input type = "text" name = "last_name">
<input type = "submit" value = "Submit">
</FORM>
Oto rzeczywisty wynik powyższego kodowania formularza. Teraz możesz wpisać imię i nazwisko, a następnie kliknąć przycisk przesyłania, aby zobaczyć wynik.
Przekazywanie informacji metodą POST
Bardziej niezawodną metodą przekazywania informacji do programu CGI jest POSTmetoda. Spowoduje to pakowanie informacji w dokładnie taki sam sposób, jak metody GET, ale zamiast wysyłać je jako ciąg tekstowy po pliku?w adresie URL wysyła go jako oddzielną wiadomość jako część nagłówka HTTP. Serwer WWW dostarcza ten komunikat do skryptu CGI w postaci standardowego wejścia.
Poniżej znajduje się zmodyfikowany hello_post.cgiskrypt do obsługi danych wprowadzanych przez przeglądarkę internetową. Ten skrypt obsługuje metodę GET i POST.
#!/usr/bin/perl
local ($buffer, @pairs, $pair, $name, $value, %FORM); # Read in text $ENV{'REQUEST_METHOD'} =~ tr/a-z/A-Z/;
if ($ENV{'REQUEST_METHOD'} eq "POST") { read(STDIN, $buffer, $ENV{'CONTENT_LENGTH'}); } else { $buffer = $ENV{'QUERY_STRING'}; } # Split information into name/value pairs @pairs = split(/&/, $buffer);
foreach $pair (@pairs) { ($name, $value) = split(/=/, $pair);
$value =~ tr/+/ /; $value =~ s/%(..)/pack("C", hex($1))/eg; $FORM{$name} = $value;
}
$first_name = $FORM{first_name};
$last_name = $FORM{last_name};
print "Content-type:text/html\r\n\r\n";
print "<html>";
print "<head>";
print "<title>Hello - Second CGI Program</title>";
print "</head>";
print "<body>";
print "<h2>Hello $first_name $last_name - Second CGI Program</h2>";
print "</body>";
print "</html>";
1;
Weźmy ponownie ten sam przykład co powyżej, który przekazuje dwie wartości za pomocą HTML FORM i przycisku przesyłania. Zamierzamy użyć skryptu CGI hello_post.cgi do obsługi tego wejścia.
<FORM action = "/cgi-bin/hello_post.cgi" method = "POST">
First Name: <input type = "text" name = "first_name"> <br>
Last Name: <input type = "text" name = "last_name">
<input type = "submit" value = "Submit">
</FORM>
Oto rzeczywisty wynik powyższego kodowania formularza, wpisujesz imię i nazwisko, a następnie kliknij przycisk przesyłania, aby zobaczyć wynik.
Przekazywanie danych pola wyboru do programu CGI
Pola wyboru są używane, gdy wymagane jest wybranie więcej niż jednej opcji. Oto przykład kodu HTML dla formularza z dwoma polami wyboru.
<form action = "/cgi-bin/checkbox.cgi" method = "POST" target = "_blank">
<input type = "checkbox" name = "maths" value = "on"> Maths
<input type = "checkbox" name = "physics" value = "on"> Physics
<input type = "submit" value = "Select Subject">
</form>
Wynikiem tego kodu jest następująca postać -
Poniżej jest checkbox.cgi skrypt do obsługi danych wejściowych podanych przez przeglądarkę internetową dla przycisku opcji.
#!/usr/bin/perl
local ($buffer, @pairs, $pair, $name, $value, %FORM);
# Read in text
$ENV{'REQUEST_METHOD'} =~ tr/a-z/A-Z/; if ($ENV{'REQUEST_METHOD'} eq "POST") {
read(STDIN, $buffer, $ENV{'CONTENT_LENGTH'});
} else {
$buffer = $ENV{'QUERY_STRING'};
}
# Split information into name/value pairs
@pairs = split(/&/, $buffer); foreach $pair (@pairs) {
($name, $value) = split(/=/, $pair); $value =~ tr/+/ /;
$value =~ s/%(..)/pack("C", hex($1))/eg;
$FORM{$name} = $value; } if( $FORM{maths} ) {
$maths_flag ="ON"; } else { $maths_flag ="OFF";
}
if( $FORM{physics} ) { $physics_flag ="ON";
} else {
$physics_flag ="OFF"; } print "Content-type:text/html\r\n\r\n"; print "<html>"; print "<head>"; print "<title>Checkbox - Third CGI Program</title>"; print "</head>"; print "<body>"; print "<h2> CheckBox Maths is : $maths_flag</h2>";
print "<h2> CheckBox Physics is : $physics_flag</h2>";
print "</body>";
print "</html>";
1;
Przekazywanie danych przycisku radiowego do programu CGI
Przyciski radiowe są używane, gdy wymagana jest tylko jedna opcja. Oto przykład kodu HTML dla formularza z dwoma przyciskami opcji -
<form action = "/cgi-bin/radiobutton.cgi" method = "POST" target = "_blank">
<input type = "radio" name = "subject" value = "maths"> Maths
<input type = "radio" name = "subject" value = "physics"> Physics
<input type = "submit" value = "Select Subject">
</form>
Wynikiem tego kodu jest następująca postać -
Poniżej jest radiobutton.cgi skrypt do obsługi danych wejściowych podanych przez przeglądarkę internetową dla przycisku opcji.
#!/usr/bin/perl
local ($buffer, @pairs, $pair, $name, $value, %FORM); # Read in text $ENV{'REQUEST_METHOD'} =~ tr/a-z/A-Z/;
if ($ENV{'REQUEST_METHOD'} eq "POST") { read(STDIN, $buffer, $ENV{'CONTENT_LENGTH'}); } else { $buffer = $ENV{'QUERY_STRING'}; } # Split information into name/value pairs @pairs = split(/&/, $buffer);
foreach $pair (@pairs) { ($name, $value) = split(/=/, $pair);
$value =~ tr/+/ /; $value =~ s/%(..)/pack("C", hex($1))/eg; $FORM{$name} = $value;
}
$subject = $FORM{subject};
print "Content-type:text/html\r\n\r\n";
print "<html>";
print "<head>";
print "<title>Radio - Fourth CGI Program</title>";
print "</head>";
print "<body>";
print "<h2> Selected Subject is $subject</h2>";
print "</body>";
print "</html>";
1;
Przekazywanie danych obszaru tekstowego do programu CGI
Element textarea jest używany, gdy tekst wielowierszowy ma zostać przesłany do programu CGI. Oto przykładowy kod HTML dla formularza z polem TEXTAREA -
<form action = "/cgi-bin/textarea.cgi" method = "POST" target = "_blank">
<textarea name = "textcontent" cols = 40 rows = 4>
Type your text here...
</textarea>
<input type = "submit" value = "Submit">
</form>
Wynikiem tego kodu jest następująca postać -
Poniżej znajduje się plik textarea.cgi skrypt do obsługi danych wprowadzanych przez przeglądarkę internetową.
#!/usr/bin/perl
local ($buffer, @pairs, $pair, $name, $value, %FORM); # Read in text $ENV{'REQUEST_METHOD'} =~ tr/a-z/A-Z/;
if ($ENV{'REQUEST_METHOD'} eq "POST") { read(STDIN, $buffer, $ENV{'CONTENT_LENGTH'}); } else { $buffer = $ENV{'QUERY_STRING'}; } # Split information into name/value pairs @pairs = split(/&/, $buffer);
foreach $pair (@pairs) { ($name, $value) = split(/=/, $pair);
$value =~ tr/+/ /; $value =~ s/%(..)/pack("C", hex($1))/eg; $FORM{$name} = $value;
}
$text_content = $FORM{textcontent};
print "Content-type:text/html\r\n\r\n";
print "<html>";
print "<head>";
print "<title>Text Area - Fifth CGI Program</title>";
print "</head>";
print "<body>";
print "<h2> Entered Text Content is $text_content</h2>";
print "</body>";
print "</html>";
1;
Przekazywanie danych z rozwijanej skrzynki do programu CGI
Rozwijane pole jest używane, gdy mamy wiele dostępnych opcji, ale tylko jedna lub dwie zostaną wybrane. Oto przykład kodu HTML dla formularza z jednym rozwijanym oknem
<form action = "/cgi-bin/dropdown.cgi" method = "POST" target = "_blank">
<select name = "dropdown">
<option value = "Maths" selected>Maths</option>
<option value = "Physics">Physics</option>
</select>
<input type = "submit" value = "Submit">
</form>
Wynikiem tego kodu jest następująca postać -
Poniżej znajduje się plik dropdown.cgi skrypt do obsługi danych wejściowych podawanych przez przeglądarkę internetową.
#!/usr/bin/perl
local ($buffer, @pairs, $pair, $name, $value, %FORM); # Read in text $ENV{'REQUEST_METHOD'} =~ tr/a-z/A-Z/;
if ($ENV{'REQUEST_METHOD'} eq "POST") { read(STDIN, $buffer, $ENV{'CONTENT_LENGTH'}); } else { $buffer = $ENV{'QUERY_STRING'}; } # Split information into name/value pairs @pairs = split(/&/, $buffer);
foreach $pair (@pairs) { ($name, $value) = split(/=/, $pair);
$value =~ tr/+/ /; $value =~ s/%(..)/pack("C", hex($1))/eg; $FORM{$name} = $value;
}
$subject = $FORM{dropdown};
print "Content-type:text/html\r\n\r\n";
print "<html>";
print "<head>";
print "<title>Dropdown Box - Sixth CGI Program</title>";
print "</head>";
print "<body>";
print "<h2> Selected Subject is $subject</h2>";
print "</body>";
print "</html>";
1;
Korzystanie z plików cookie w CGI
Protokół HTTP jest protokołem bezstanowym. Jednak w przypadku komercyjnej witryny internetowej wymagane jest przechowywanie informacji o sesjach między różnymi stronami. Na przykład rejestracja jednego użytkownika kończy się po transakcji obejmującej wiele stron. Ale jak zachować informacje o sesji użytkownika na wszystkich stronach internetowych?
W wielu sytuacjach używanie plików cookie jest najskuteczniejszą metodą zapamiętywania i śledzenia preferencji, zakupów, prowizji i innych informacji wymaganych dla lepszych wrażeń odwiedzających lub statystyk witryny.
Jak to działa
Twój serwer wysyła pewne dane do przeglądarki odwiedzającego w formie pliku cookie. Przeglądarka może zaakceptować plik cookie. Jeśli tak, jest przechowywany jako zwykły zapis tekstowy na dysku twardym gościa. Teraz, gdy użytkownik przejdzie na inną stronę w Twojej witrynie, plik cookie jest dostępny do pobrania. Po odzyskaniu serwer wie / pamięta, co zostało zapisane.
Pliki cookie to zapis danych w postaci zwykłego tekstu składający się z 5 pól o zmiennej długości -
Expires- data wygaśnięcia pliku cookie. Jeśli jest puste, plik cookie wygaśnie, gdy odwiedzający zamknie przeglądarkę.
Domain - nazwa domeny Twojej witryny.
Path- Ścieżka do katalogu lub strony internetowej, która ustawiła plik cookie. To może być puste, jeśli chcesz pobrać plik cookie z dowolnego katalogu lub strony.
Secure- Jeśli to pole zawiera słowo „bezpieczny”, plik cookie można pobrać tylko z bezpiecznego serwera. Jeśli to pole jest puste, takie ograniczenie nie istnieje.
Name = Value - Pliki cookie są ustawiane i przeglądane w postaci par klucza i wartości.
Konfiguracja plików cookie
Wysyłanie plików cookie do przeglądarki jest bardzo łatwe. Te pliki cookie będą wysyłane wraz z nagłówkiem HTTP. Zakładając, że chcesz ustawić identyfikator użytkownika i hasło jako pliki cookie. Więc zostanie to zrobione w następujący sposób -
#!/usr/bin/perl
print "Set-Cookie:UserID = XYZ;\n";
print "Set-Cookie:Password = XYZ123;\n";
print "Set-Cookie:Expires = Tuesday, 31-Dec-2007 23:12:40 GMT";\n";
print "Set-Cookie:Domain = www.tutorialspoint.com;\n";
print "Set-Cookie:Path = /perl;\n";
print "Content-type:text/html\r\n\r\n";
...........Rest of the HTML Content goes here....
Tutaj używaliśmy Set-CookieNagłówek HTTP do ustawiania plików cookie. Opcjonalne jest ustawienie atrybutów plików cookie, takich jak Wygasa, Domena i Ścieżka. Należy pamiętać, że pliki cookie są ustawiane przed wysłaniem magicznej linii"Content-type:text/html\r\n\r\n.
Pobieranie plików cookie
Pobranie wszystkich ustawionych plików cookie jest bardzo łatwe. Pliki cookie są przechowywane w zmiennej środowiskowej CGI HTTP_COOKIE i będą miały następującą postać.
key1 = value1;key2 = value2;key3 = value3....
Oto przykład pobierania plików cookie.
#!/usr/bin/perl
$rcvd_cookies = $ENV{'HTTP_COOKIE'}; @cookies = split /;/, $rcvd_cookies;
foreach $cookie ( @cookies ) { ($key, $val) = split(/=/, $cookie); # splits on the first =.
$key =~ s/^\s+//; $val =~ s/^\s+//;
$key =~ s/\s+$//;
$val =~ s/\s+$//;
if( $key eq "UserID" ) { $user_id = $val; } elsif($key eq "Password") {
$password = $val;
}
}
print "User ID = $user_id\n"; print "Password = $password\n";
Daje to następujący wynik, pod warunkiem, że powyższe pliki cookie zostały ustawione przed wywołaniem skryptu pobierania plików cookie.
User ID = XYZ
Password = XYZ123
Moduły i biblioteki CGI
W Internecie znajdziesz wiele wbudowanych modułów, które zapewniają bezpośrednie funkcje do wykorzystania w programie CGI. Oto najważniejsze raz.
Moduł CGI
Berkeley cgi-lib.pl
Co to są pakiety?
Plik packageinstrukcja przełącza bieżący kontekst nazewnictwa na określoną przestrzeń nazw (tablicę symboli). Zatem -
Pakiet to zbiór kodu, który znajduje się we własnej przestrzeni nazw.
Przestrzeń nazw to nazwana kolekcja unikatowych nazw zmiennych (nazywana również tablicą symboli).
Przestrzenie nazw zapobiegają kolizjom nazw zmiennych między pakietami.
Pakiety umożliwiają tworzenie modułów, które, gdy są używane, nie blokują zmiennych i funkcji poza własną przestrzenią nazw modułów.
Pakiet obowiązuje do momentu wywołania innej instrukcji pakietu lub do końca bieżącego bloku lub pliku.
Możesz jawnie odwoływać się do zmiennych w pakiecie przy użyciu rozszerzenia :: kwalifikator pakietu.
Poniżej znajduje się przykład z pakietami main i Foo w pliku. Tutaj specjalna zmienna __PACKAGE__ została użyta do wydrukowania nazwy pakietu.
#!/usr/bin/perl
# This is main package
$i = 1; print "Package name : " , __PACKAGE__ , " $i\n";
package Foo;
# This is Foo package
$i = 10; print "Package name : " , __PACKAGE__ , " $i\n";
package main;
# This is again main package
$i = 100; print "Package name : " , __PACKAGE__ , " $i\n";
print "Package name : " , __PACKAGE__ , " $Foo::i\n";
1;
Wykonanie powyższego kodu daje następujący wynik -
Package name : main 1
Package name : Foo 10
Package name : main 100
Package name : main 10
Bloki BEGIN i END
Możesz zdefiniować dowolną liczbę bloków kodu o nazwie BEGIN i END, które działają odpowiednio jako konstruktory i destruktory.
BEGIN { ... }
END { ... }
BEGIN { ... }
END { ... }
Każdy BEGIN blok jest wykonywany po załadowaniu i skompilowaniu skryptu Perla, ale przed wykonaniem jakiejkolwiek innej instrukcji.
Każdy blok END jest wykonywany tuż przed zakończeniem pracy interpretera perla.
Bloki BEGIN i END są szczególnie przydatne podczas tworzenia modułów Perla.
Poniższy przykład pokazuje jego użycie -
#!/usr/bin/perl
package Foo;
print "Begin and Block Demo\n";
BEGIN {
print "This is BEGIN Block\n"
}
END {
print "This is END Block\n"
}
1;
Wykonanie powyższego kodu daje następujący wynik -
This is BEGIN Block
Begin and Block Demo
This is END Block
Co to są moduły Perla?
Moduł Perla to pakiet wielokrotnego użytku zdefiniowany w pliku biblioteki, którego nazwa jest taka sama jak nazwa pakietu z rozszerzeniem .pm.
Plik modułu Perla o nazwie Foo.pm może zawierać takie stwierdzenia.
#!/usr/bin/perl
package Foo;
sub bar {
print "Hello $_[0]\n"
}
sub blat {
print "World $_[0]\n"
}
1;
Kilka ważnych punktów na temat modułów Perla
Funkcje require i use załaduje moduł.
Oba używają listy ścieżek wyszukiwania w @INC znaleźć moduł.
Obie funkcje require i use Zadzwoń do eval funkcja do przetworzenia kodu.
Plik 1; na dole powoduje, że eval oceniany jest na TRUE (a zatem nie zawiedzie).
Funkcja Require
Moduł można załadować, wywołując metodę require działają w następujący sposób -
#!/usr/bin/perl
require Foo;
Foo::bar( "a" );
Foo::blat( "b" );
Musiałeś zauważyć, że nazwy podprogramów muszą być w pełni kwalifikowane, aby je wywołać. Byłoby miło włączyć podprogrambar i blat do zaimportowania do naszej własnej przestrzeni nazw, więc nie musielibyśmy używać kwalifikatora Foo ::.
Funkcja Use
Moduł można załadować, wywołując metodę use funkcjonować.
#!/usr/bin/perl
use Foo;
bar( "a" );
blat( "b" );
Zauważ, że nie musieliśmy w pełni kwalifikować nazw funkcji pakietu. Plikuse funkcja wyeksportuje listę symboli z modułu po dodaniu kilku instrukcji wewnątrz modułu.
require Exporter;
@ISA = qw(Exporter);
Następnie podaj listę symboli (skalary, listy, skróty, podprogramy itp.), Wypełniając zmienną listy o nazwie @EXPORT: Na przykład -
package Module;
require Exporter;
@ISA = qw(Exporter);
@EXPORT = qw(bar blat);
sub bar { print "Hello $_[0]\n" }
sub blat { print "World $_[0]\n" } sub splat { print "Not $_[0]\n" } # Not exported!
1;
Utwórz drzewo modułów Perla
Kiedy jesteś gotowy do wysyłki swojego modułu Perla, istnieje standardowy sposób tworzenia drzewa modułów Perl. Odbywa się to za pomocąh2xsużyteczność. To narzędzie jest dostarczane wraz z Perlem. Oto składnia użycia h2xs -
$h2xs -AX -n ModuleName
Na przykład, jeśli Twój moduł jest dostępny w Person.pm plik, a następnie po prostu wydaj następujące polecenie -
$h2xs -AX -n Person
To da następujący wynik -
Writing Person/lib/Person.pm
Writing Person/Makefile.PL
Writing Person/README
Writing Person/t/Person.t
Writing Person/Changes
Writing Person/MANIFEST
Oto opis tych opcji -
-A pomija kod Autoloadera (najlepiej używany przez moduły, które definiują dużą liczbę rzadko używanych podprogramów).
-X pomija elementy XS (eXternal Subroutine, gdzie eXternal oznacza zewnętrzne w stosunku do Perla, tj. C).
-n określa nazwę modułu.
Więc powyższe polecenie tworzy następującą strukturę w katalogu Person. Rzeczywisty wynik pokazano powyżej.
- Changes
- Makefile.PL
- MANIFEST (zawiera listę wszystkich plików w pakiecie)
- README
- t / (pliki testowe)
- lib / (Tutaj znajduje się rzeczywisty kod źródłowy
Więc w końcu ty tartę strukturę katalogów do pliku Person.tar.gz i można go wysłać. Będziesz musiał zaktualizować plik README za pomocą odpowiednich instrukcji. Możesz także dostarczyć kilka plików przykładów testowych w katalogu t.
Instalowanie modułu Perl
Pobierz moduł Perla w postaci pliku tar.gz. Użyj poniższej sekwencji, aby zainstalować dowolny moduł PerlaPerson.pm który został pobrany jako Person.tar.gz plik.
tar xvfz Person.tar.gz
cd Person
perl Makefile.PL
make
make install
Interpreter Perla ma listę katalogów, w których szuka modułów (tablica globalna @INC).
Możesz używać Perla na różne sposoby, aby tworzyć nowe procesy zgodnie z własnymi wymaganiami. Ten samouczek zawiera listę kilku ważnych i najczęściej używanych metod tworzenia i zarządzania procesami Perla.
Możesz użyć specjalnych zmiennych $$ lub $PROCESS_ID aby uzyskać bieżący identyfikator procesu.
Każdy proces utworzony za pomocą którejkolwiek z wymienionych metod zachowuje swoje własne wirtualne środowisko %ENV zmienna.
Plik exit() function zawsze kończy tylko proces potomny, który wykonuje tę funkcję, a proces główny jako całość nie zakończy się, chyba że zakończą się wszystkie uruchomione procesy potomne.
Wszystkie otwarte uchwyty są dup () - ed w procesach potomnych, więc zamknięcie któregokolwiek z uchwytów w jednym procesie nie wpływa na inne.
Operator Backstick
Najprostszym sposobem wykonania dowolnego polecenia Uniksa jest użycie operatora backstick. Po prostu umieszczasz swoje polecenie wewnątrz operatora backstick, co spowoduje wykonanie polecenia i zwróci jego wynik, który można zapisać w następujący sposób -
#!/usr/bin/perl
@files = `ls -l`;
foreach $file (@files) { print $file;
}
1;
Kiedy powyższy kod jest wykonywany, wyświetla listę wszystkich plików i katalogów dostępnych w bieżącym katalogu -
drwxr-xr-x 3 root root 4096 Sep 14 06:46 9-14
drwxr-xr-x 4 root root 4096 Sep 13 07:54 android
-rw-r--r-- 1 root root 574 Sep 17 15:16 index.htm
drwxr-xr-x 3 544 401 4096 Jul 6 16:49 MIME-Lite-3.01
-rw-r--r-- 1 root root 71 Sep 17 15:16 test.pl
drwx------ 2 root root 4096 Sep 17 15:11 vAtrJdy
Funkcja system ()
Możesz także użyć system()funkcja do wykonania dowolnego polecenia systemu Unix, którego dane wyjściowe trafią do wyjścia skryptu Perla. Domyślnie jest to ekran, czyli STDOUT, ale można go przekierować do dowolnego pliku za pomocą operatora przekierowania> -
#!/usr/bin/perl
system( "ls -l")
1;
Kiedy powyższy kod jest wykonywany, wyświetla listę wszystkich plików i katalogów dostępnych w bieżącym katalogu -
drwxr-xr-x 3 root root 4096 Sep 14 06:46 9-14
drwxr-xr-x 4 root root 4096 Sep 13 07:54 android
-rw-r--r-- 1 root root 574 Sep 17 15:16 index.htm
drwxr-xr-x 3 544 401 4096 Jul 6 16:49 MIME-Lite-3.01
-rw-r--r-- 1 root root 71 Sep 17 15:16 test.pl
drwx------ 2 root root 4096 Sep 17 15:11 vAtrJdy
Uważaj, gdy twoje polecenie zawiera zmienne środowiskowe powłoki, takie jak $PATH or $DOM. Wypróbuj trzy scenariusze -
#!/usr/bin/perl
$PATH = "I am Perl Variable"; system('echo $PATH'); # Treats $PATH as shell variable system("echo $PATH"); # Treats $PATH as Perl variable system("echo \$PATH"); # Escaping $ works.
1;
Wykonanie powyższego kodu daje następujący wynik w zależności od tego, co jest ustawione w zmiennej powłoki $ PATH.
/usr/local/bin:/bin:/usr/bin:/usr/local/sbin:/usr/sbin:/sbin
I am Perl Variable
/usr/local/bin:/bin:/usr/bin:/usr/local/sbin:/usr/sbin:/sbin
Funkcja fork ()
Perl udostępnia fork()funkcja, która odpowiada wywołaniu systemowemu Unix o tej samej nazwie. Na większości platform podobnych do Uniksa, na których funkcja systemowa fork () jest dostępna, funkcja fork () w Perlu po prostu ją wywołuje. Na niektórych platformach, takich jak Windows, gdzie wywołanie systemowe fork () nie jest dostępne, Perl można zbudować tak, aby emulował fork () na poziomie interpretera.
Funkcja fork () służy do klonowania bieżącego procesu. To wywołanie tworzy nowy proces uruchamiający ten sam program w tym samym punkcie. Zwraca pid podrzędny do procesu nadrzędnego, 0 do procesu potomnego lub undef, jeśli rozwidlenie zakończyło się niepowodzeniem.
Możesz użyć exec() funkcja w procesie, aby uruchomić żądany plik wykonywalny, który zostanie wykonany w oddzielnym obszarze procesu, a funkcja exec () będzie czekać na jego zakończenie, zanim zakończy pracę z tym samym kodem zakończenia co ten proces.
#!/usr/bin/perl
if(!defined($pid = fork())) { # fork returned undef, so unsuccessful die "Cannot fork a child: $!";
} elsif ($pid == 0) { print "Printed by child process\n"; exec("date") || die "can't exec date: $!";
} else {
# fork returned 0 nor undef
# so this branch is parent
print "Printed by parent process\n";
$ret = waitpid($pid, 0);
print "Completed process id: $ret\n";
}
1;
Wykonanie powyższego kodu daje następujący wynik -
Printed by parent process
Printed by child process
Tue Sep 17 15:41:08 CDT 2013
Completed process id: 17777
Plik wait() i waitpid()można przekazać jako identyfikator pseudoprocesu zwracany przez fork (). Te wywołania będą poprawnie czekać na zakończenie pseudoprocesu i zwrócą jego stan. Jeśli widelec, nigdy nie czekając, aż twoje dzieci będą używaćwaitpid()funkcja, będziesz gromadzić zombie. W systemach uniksowych możesz tego uniknąć ustawiając $ SIG {CHLD} na "IGNORE" w następujący sposób -
#!/usr/bin/perl
local $SIG{CHLD} = "IGNORE"; if(!defined($pid = fork())) {
# fork returned undef, so unsuccessful
die "Cannot fork a child: $!"; } elsif ($pid == 0) {
print "Printed by child process\n";
exec("date") || die "can't exec date: $!"; } else { # fork returned 0 nor undef # so this branch is parent print "Printed by parent process\n"; $ret = waitpid($pid, 0); print "Completed process id: $ret\n";
}
1;
Wykonanie powyższego kodu daje następujący wynik -
Printed by parent process
Printed by child process
Tue Sep 17 15:44:07 CDT 2013
Completed process id: -1
Funkcja kill ()
Perl kill('KILL', (Process List)) funkcja może być użyta do zakończenia pseudoprocesu poprzez przekazanie mu ID zwróconego przez fork ().
Zauważ, że użycie funkcji kill ('KILL', (Lista procesów)) w pseudo-procesie () może zwykle powodować wycieki pamięci, ponieważ wątek implementujący pseudoproces nie ma szansy na wyczyszczenie swoich zasobów.
Możesz użyć kill() funkcja do wysyłania dowolnego innego sygnału do procesów docelowych, na przykład następująca wyśle SIGINT do ID procesu 104 i 102 -
#!/usr/bin/perl
kill('INT', 104, 102);
1;
Możesz osadzić dokumentację Pod (zwykły stary tekst) w swoich modułach i skryptach Perla. Poniżej znajduje się zasada korzystania z dokumentacji osadzonej w kodzie Perla -
Rozpocznij dokumentację od pustej linii, a =head1 polecenie na początku i zakończ je znakiem =cut
Perl zignoruje tekst Poda wprowadzony w kodzie. Poniżej znajduje się prosty przykład użycia dokumentacji osadzonej w kodzie Perla -
#!/usr/bin/perl
print "Hello, World\n";
=head1 Hello, World Example
This example demonstrate very basic syntax of Perl.
=cut
print "Hello, Universe\n";
Wykonanie powyższego kodu daje następujący wynik -
Hello, World
Hello, Universe
Jeśli zamierzasz umieścić swój Pod na końcu pliku i używasz znaku cięcia __END__ lub __DATA__, pamiętaj, aby umieścić pusty wiersz przed pierwszym poleceniem Poda w następujący sposób, w przeciwnym razie bez pustej linii przed =head1, wielu tłumaczy nie rozpoznałoby znaku =head1 jako rozpoczęcie bloku Pod.
#!/usr/bin/perl
print "Hello, World\n";
while(<DATA>) {
print $_;
}
__END__
=head1 Hello, World Example
This example demonstrate very basic syntax of Perl.
print "Hello, Universe\n";
Wykonanie powyższego kodu daje następujący wynik -
Hello, World
=head1 Hello, World Example
This example demonstrate very basic syntax of Perl.
print "Hello, Universe\n";
Weźmy jeszcze jeden przykład dla tego samego kodu bez czytania części DANE -
#!/usr/bin/perl
print "Hello, World\n";
__END__
=head1 Hello, World Example
This example demonstrate very basic syntax of Perl.
print "Hello, Universe\n";
Wykonanie powyższego kodu daje następujący wynik -
Hello, World
Co to jest POD?
Pod to prosty w użyciu język znaczników używany do pisania dokumentacji dla Perla, programów w Perlu i modułów Perla. Dostępnych jest wielu tłumaczy umożliwiających konwersję Poda do różnych formatów, takich jak zwykły tekst, HTML, strony podręcznika i inne. Znaczniki pod składają się z trzech podstawowych rodzajów akapitów -
Ordinary Paragraph - Możesz używać kodów formatowania w zwykłych akapitach, pogrubienia, kursywy, stylu kodu, hiperłączy i nie tylko.
Verbatim Paragraph - Dosłowne akapity są zwykle używane do prezentowania bloku kodu lub innego tekstu, który nie wymaga specjalnego przetwarzania ani formatowania i który nie powinien być zawijany.
Command Paragraph- Akapit polecenia jest używany do specjalnego traktowania całych fragmentów tekstu, zwykle jako nagłówków lub części list. Wszystkie akapity poleceń zaczynają się od znaku =, po którym następuje identyfikator, po którym następuje dowolny tekst, którego polecenie może użyć w dowolny sposób. Obecnie rozpoznawane polecenia to -
=pod
=head1 Heading Text
=head2 Heading Text
=head3 Heading Text
=head4 Heading Text
=over indentlevel
=item stuff
=back
=begin format
=end format
=for format text...
=encoding type
=cut
Przykłady POD
Rozważ następujący POD -
=head1 SYNOPSIS
Copyright 2005 [TUTORIALSOPOINT].
=cut
Możesz użyć pod2html narzędzie dostępne w systemie Linux do konwersji powyższego POD na HTML, dzięki czemu da następujący wynik -
Następnie rozważ następujący przykład -
=head2 An Example List
=over 4
=item * This is a bulleted list.
=item * Here's another item.
=back
=begin html
<p>
Here's some embedded HTML. In this block I can
include images, apply <span style="color: green">
styles</span>, or do anything else I can do with
HTML. pod parsers that aren't outputting HTML will
completely ignore it.
</p>
=end html
Kiedy przekonwertujesz powyższy POD na HTML za pomocą pod2html, da to następujący wynik -
An Example List
This is a bulleted list.
Here's another item.
Here's some embedded HTML. In this block I can include images, apply
styles, or do anything else I can do with HTML. pod parsers that aren't
outputting HTML will completely ignore it.
Oto lista wszystkich ważnych funkcji obsługiwanych przez standardowy Perl.
abs - funkcja wartości bezwzględnej
accept - zaakceptuj połączenie przychodzące
alarm - zaplanuj SIGALRM
atan2 - arcus tangens Y / X w zakresie -PI do PI
bind - wiąże adres z gniazdem
binmode - przygotuj pliki binarne do wejścia / wyjścia
błogosław - stwórz obiekt
caller - pobierz kontekst bieżącego wywołania podprogramu
chdir - zmień aktualny katalog roboczy
chmod - zmienia uprawnienia na liście plików
chomp - usuwa końcowy separator rekordów z łańcucha
chop - usuwa ostatni znak z łańcucha
chown - zmień uprawnienia na liście plików
chr - pobierz znak, który reprezentuje ta liczba
chroot - tworzy katalog jako nowy katalog główny do wyszukiwania ścieżek
close - zamknij uchwyt pilnika (lub rury lub gniazda)
closedir - zamknij uchwyt katalogu
connect - podłącz do zdalnego gniazda
continue - opcjonalny końcowy blok za chwilę lub na zawsze
cos - funkcja cosinus
crypt - jednokierunkowe szyfrowanie typu passwd
dbmclose - przerywa wiązanie w powiązanym pliku dbm
dbmopen - utwórz powiązanie w powiązanym pliku dbm
zdefiniowane - sprawdź, czy wartość, zmienna lub funkcja jest zdefiniowana, czy nie
delete - usuwa wartość z hasha
die - zgłoś wyjątek lub wyskocz
do - zamień BLOK w TERM
dump - utwórz natychmiastowy zrzut pamięci
each - pobierz następną parę klucz / wartość z skrótu
endgrent - można to zrobić za pomocą pliku grupy
endhostent - można to zrobić za pomocą pliku hosts
endnetent - można to zrobić za pomocą pliku sieci
endprotoent - można to zrobić za pomocą pliku protokołów
endpwent - można to zrobić używając pliku passwd
endervent - można to zrobić za pomocą pliku services
eof - przetestuj uchwyt pliku pod kątem jego końca
eval - łap wyjątki lub kompiluj i uruchamiaj kod
exec - porzuć ten program, aby uruchomić inny
istnieje - sprawdź, czy klucz hash jest obecny
exit - zakończ ten program
exp - podbij I
do potęgi fcntl - wywołanie systemu kontroli plików
fileno - zwraca deskryptor pliku z uchwytu pliku
flock - zablokuj cały plik za pomocą blokady doradczej
widelec - utwórz nowy proces, taki jak ten
format - deklaruj format obrazu przy użyciu funkcji write ()
formline - wewnętrzna funkcja używana do formatów
getc - pobierz następny znak z uchwytu pliku
getgrent - pobierz następny rekord grupy
getgrgid - pobierz rekord grupy o podanym identyfikatorze użytkownika grupy
getgrnam - pobierz rekord grupy o podanej nazwie grupy
gethostbyaddr - pobierz rekord hosta podając jego adres
gethostbyname - pobierz nazwę rekordu hosta
gethostent - pobierz rekord następnego hosta
getlogin - zwraca kto zalogował się na tym terminalu
getnetbyaddr - pobierz rekord sieciowy podając jego adres
getnetbyname - pobiera dane sieci o podanej nazwie
getnetent - pobierz następny rekord sieci
getpeername - znajdź drugi koniec połączenia gniazda
getpgrp - pobierz grupę procesów
getppid - pobierz identyfikator procesu nadrzędnego
getpriority - pobierz aktualną wartość nice
getprotobyname - pobierz nazwę rekordu protokołu
getprotobynumber - pobierz protokół numeryczny rekordu protokołu
getprotoent - pobierz następny rekord protokołów
getpwent - pobierz następny rekord passwd
getpwnam - pobierz rekord passwd o podanej nazwie użytkownika
getpwuid - pobierz rekord passwd o podanym identyfikatorze użytkownika
getservbyname - pobierz rekord usług podając jego nazwę
getservbyport - pobierz rekord usługi podany numeryczny port
getservent - zdobądź następny rekord usług
getsockname - pobierz sockaddr dla danego gniazda
getsockopt - pobierz opcje gniazda dla danego gniazda
glob - rozwiń nazwy plików za pomocą symboli wieloznacznych
gmtime - konwertuje czas UNIX na rekord lub łańcuch przy użyciu formatu czasu Greenwich.
goto - utwórz kod spaghetti
grep - zlokalizuj elementy na liście, sprawdź zgodność z podanym kryterium
hex - zamień ciąg na liczbę szesnastkową
import - załataj przestrzeń nazw modułu na swoją własną
indeks - znajdź podciąg w ciągu
int - uzyskaj część całkowitą liczby
ioctl - zależne od systemu wywołanie systemowe sterowania urządzeniami
join - łączy listę w łańcuch za pomocą separatora
klucze - pobieranie listy indeksów z hasha
kill - wyślij sygnał do procesu lub grupy procesów
ostatni - przedwcześnie opuść blok
lc - zwraca wersję łańcucha napisaną małymi literami
lcfirst - zwraca łańcuch zawierający tylko następną małą literę
length - zwraca liczbę bajtów w ciągu
link - utwórz twardy link w pliku plików
słuchaj - zarejestruj swoje gniazdo jako serwer
local - utwórz tymczasową wartość dla zmiennej globalnej (dynamiczne określanie zakresu)
localtime - konwertuje czas UNIX na rekord lub łańcuch przy użyciu czasu lokalnego
lock - uzyskuje blokadę wątku na zmiennej, podprogramie lub metodzie
log - pobierz logarytm naturalny dla liczby
lstat - stat dowiązanie symboliczne
m - dopasuj ciąg do wzorca wyrażenia regularnego
mapa - zastosuj zmianę do listy, aby wrócić do nowej listy ze zmianami
mkdir - utwórz katalog
msgctl - operacje kontroli wiadomości SysV IPC
msgget - pobierz kolejkę komunikatów SysV IPC
msgrcv - odbierz wiadomość SysV IPC z kolejki wiadomości
msgsnd - wyślij wiadomość SysV IPC do kolejki wiadomości
my - deklaruj i przypisz zmienną lokalną (zakres leksykalny)
next - przedwcześnie wykonaj iterację bloku
no - nie importuj niektórych symboli lub semantyki modułu w czasie kompilacji
oct - konwertuje ciąg na liczbę ósemkową
open - otwórz plik, potok lub deskryptor
opendir - otwórz katalog
ord - znajdź numeryczną reprezentację znaku
nasz - zadeklaruj i przypisz zmienną pakietu (zakres leksykalny)
pack - zamień listę na reprezentację binarną
pakiet - deklaruj oddzielną globalną przestrzeń nazw
potok - otwórz parę połączonych uchwytów plików
pop - usuwa ostatni element z tablicy i zwraca go
pos - znajdź lub ustaw przesunięcie dla ostatniego / następnego wyszukiwania m // g
print - wyświetla listę do uchwytu pliku
printf - wypisuje sformatowaną listę do uchwytu pliku
prototype - pobierz prototyp (jeśli istnieje) podprogramu
push - dołącz jeden lub więcej elementów do tablicy
q - cytuje pojedynczo ciąg
qq - podwójnie zacytuj ciąg
qr - Kompiluj wzorzec
quotemeta - cytuj magiczne znaki wyrażenia regularnego
qw - cytuje listę słów
qx - odwrotny cudzysłów cytuje ciąg
rand - pobiera następny numer pseudolosowy
read - buforowane wejście o stałej długości z uchwytu pliku
readdir - pobierz katalog z uchwytu katalogu
readline - pobiera rekord z pliku
readlink - określa, gdzie wskazuje łącze symboliczne
readpipe - wykonuje polecenie systemowe i zbiera standardowe wyjście
recv - otrzymaj wiadomość przez Socket
redo - rozpocznij tę iterację pętli od nowa
ref - znajdź typ rzeczy, do której się odwołujesz
rename - zmień nazwę pliku
require - ładuj funkcje zewnętrzne z biblioteki w czasie wykonywania
reset - wyczyść wszystkie zmienne o podanej nazwie
return - wcześnie wyjdź z funkcji
reverse - odwraca łańcuch lub listę
rewinddir - resetowanie uchwytu katalogu
rindex - wyszukiwanie podciągów od prawej do lewej
rmdir - usuwa katalog
s - zamień wzorzec na ciąg
skalar - wymusza kontekst skalarny
seek - wskaźnik zmiany położenia pliku dla wejścia / wyjścia o swobodnym dostępie
seekdir - wskaźnik zmiany położenia katalogu
select - zresetuj domyślne wyjście lub wykonaj multipleksowanie I / O
semctl - operacje sterowania semaforem SysV
semget - pobierz zestaw semaforów SysV
semop - operacje na semaforze SysV
send - wyślij wiadomość przez gniazdo
setgrent - przygotuj plik grupowy do użytku
sethostent - przygotuj plik hosts do użytku
setnetent - przygotuj plik sieciowy do użytku
setpgrp - ustaw grupę procesów procesu
setpriority - ustaw ładną wartość procesu
setprotoent - przygotuj plik protokołów do użytku
setpwent - przygotuj plik passwd do użytku
setservent - przygotuj plik usług do użytku
setsockopt - ustaw kilka opcji gniazda
shift - usuwa pierwszy element tablicy i zwraca go
shmctl - operacje na pamięci współdzielonej SysV
shmget - pobierz identyfikator segmentu pamięci współdzielonej SysV
shmread - odczytaj pamięć współdzieloną SysV
shmwrite - zapisuje pamięć współdzieloną SysV
shutdown - zamknij tylko połowę połączenia gniazda
sin - zwraca sinus liczby
sen - blokada na określoną liczbę sekund
gniazdo - utwórz gniazdo
socketpair - utwórz parę gniazd
sort - sortuj listę wartości
splice - dodaj lub usuń elementy w dowolnym miejscu tablicy
split - podziel ciąg za pomocą separatora wyrażenia regularnego
sprintf - wydruk sformatowany w łańcuchu
sqrt - funkcja pierwiastka kwadratowego
srand - zaszczepi generator liczb losowych
stat - pobierz informacje o statusie pliku
badanie - optymalizuj dane wejściowe pod kątem powtarzanych wyszukiwań
sub - deklaruj podprogram, prawdopodobnie anonimowo
substr - pobierz lub zmień część mieszania
dowiązanie symboliczne - utwórz dowiązanie symboliczne do pliku
syscall - wykonuje dowolne wywołanie systemowe
sysopen - otwórz plik, potok lub deskryptor
sysread - niebuforowane wejście o stałej długości z uchwytu pliku
sysseek - umieszcza wskaźnik I / O na uchwycie używanym z sysread i syswrite
system - uruchom osobny program
syswrite - niebuforowane wyjście o stałej długości do uchwytu pliku
tell - pobierz bieżący seekpointer na uchwyt pliku
telldir - pobierz aktualny seekpointer do uchwytu katalogu
tie - wiąże zmienną z klasą obiektów
tied - pobierz odniesienie do obiektu będącego podstawą powiązanej zmiennej
time - zwracana liczba sekund od 1970 roku
czasy - zwraca upływający czas dla procesów własnych i potomnych
tr - transliteracja ciągu
truncate - skróć plik
uc - zwraca wersję łańcucha napisaną wielkimi literami
ucfirst - zwraca łańcuch zawierający tylko następną wielką literę
umask - ustaw maskę trybu tworzenia plików
undef - usuwa definicję zmiennej lub funkcji
unlink - usuwa jedno łącze do pliku
unpack - konwertuje strukturę binarną na normalne zmienne perla
unshift - dołącz więcej elementów na początek listy
untie - przerywa wiązanie powiązania ze zmienną
use - załaduj moduł w czasie kompilacji
utime - ustawia ostatni dostęp do pliku i modyfikuje czasy
wartości - zwraca listę wartości w skrócie
vec - testuje lub ustawia określone bity w ciągu
czekaj - poczekaj, aż jakiekolwiek dziecko umrze
waitpid - czekaj na śmierć konkretnego procesu dziecka
wantarray - pobierz kontekst void vs skalar vs list bieżącego wywołania podprogramu
warn - wyświetla informacje o debugowaniu
napisz - wydrukuj zapis obrazu
-X - test pliku (-r, -x itp.)
y - transliteracja ciągu