Perl - Guide rapide

Perl est un langage de programmation à usage général développé à l'origine pour la manipulation de texte et maintenant utilisé pour un large éventail de tâches, y compris l'administration système, le développement Web, la programmation réseau, le développement d'interface graphique, etc.

Qu'est-ce que Perl?

  • Perl est un langage de programmation stable et multiplateforme.

  • Bien que Perl ne soit pas officiellement un acronyme, peu de gens l'ont utilisé comme Practical Extraction and Report Language.

  • Il est utilisé pour des projets critiques dans les secteurs public et privé.

  • Perl est un logiciel Open Source , sous licence sous sa licence artistique ou sous la licence publique générale GNU (GPL) .

  • Perl a été créé par Larry Wall.

  • Perl 1.0 a été publié sur alt.comp.sources d'usenet en 1987.

  • Au moment de la rédaction de ce tutoriel, la dernière version de perl était la 5.16.2.

  • Perl est répertorié dans l' Oxford English Dictionary .

PC Magazine a annoncé Perl comme finaliste pour son Prix d'Excellence Technique 1998 dans la catégorie Outil de Développement.

Fonctionnalités Perl

  • Perl utilise les meilleures fonctionnalités d'autres langages, tels que C, awk, sed, sh et BASIC, entre autres.

  • Interface d'intégration de base de données Perls DBI prend en charge les bases de données tierces, notamment Oracle, Sybase, Postgres, MySQL et autres.

  • Perl fonctionne avec HTML, XML et d'autres langages de balisage.

  • Perl prend en charge Unicode.

  • Perl est conforme à l'an 2000.

  • Perl prend en charge la programmation procédurale et orientée objet.

  • Perl s'interface avec des bibliothèques C / C ++ externes via XS ou SWIG.

  • Perl est extensible. Il existe plus de 20 000 modules tiers disponibles sur le réseau complet d'archives Perl ( CPAN ).

  • L'interpréteur Perl peut être intégré dans d'autres systèmes.

Perl et le Web

  • Perl était le langage de programmation Web le plus populaire en raison de ses capacités de manipulation de texte et de son cycle de développement rapide.

  • Perl est largement connu comme " le ruban adhésif de l'Internet ".

  • Perl peut gérer les données Web cryptées, y compris les transactions de commerce électronique.

  • Perl peut être intégré aux serveurs Web pour accélérer le traitement jusqu'à 2000%.

  • Le mod_perl de Perl permet au serveur Web Apache d'intégrer un interpréteur Perl.

  • Le package DBI de Perl facilite l'intégration de la base de données Web.

Perl est interprété

Perl est un langage interprété, ce qui signifie que votre code peut être exécuté tel quel, sans étape de compilation qui crée un programme exécutable non portable.

Les compilateurs traditionnels convertissent les programmes en langage machine. Lorsque vous exécutez un programme Perl, il est d'abord compilé en un code d'octet, qui est ensuite converti (au fur et à mesure que le programme s'exécute) en instructions machine. Ce n'est donc pas tout à fait la même chose que les shells, ou Tcl, qui sontstrictly interprété sans représentation intermédiaire.

Ce n'est pas non plus comme la plupart des versions de C ou C ++, qui sont compilées directement dans un format dépendant de la machine. Il est quelque part entre les deux, avec les fichiers Python et awk et Emacs .elc.

Avant de commencer à écrire nos programmes Perl, voyons comment configurer notre environnement Perl. Perl est disponible sur une grande variété de plates-formes -

  • Unix (Solaris, Linux, FreeBSD, AIX, HP / UX, SunOS, IRIX etc.)
  • Gagnez 9x / NT / 2000 /
  • WinCE
  • Macintosh (PPC, 68 Ko)
  • Solaris (x86, SPARC)
  • OpenVMS
  • Alpha (7.2 et versions ultérieures)
  • Symbian
  • Debian GNU / kFreeBSD
  • MirOS BSD
  • Et beaucoup plus...

Il est plus probable que perl soit installé sur votre système. Essayez simplement de donner la commande suivante à l'invite $ -

$perl -v

Si vous avez installé perl sur votre machine, vous recevrez un message comme suit -

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.

Si vous n'avez pas déjà installé Perl, passez à la section suivante.

Obtenir l'installation de Perl

Le code source, les binaires, la documentation, les actualités, etc. les plus à jour et les plus récents sont disponibles sur le site officiel de Perl.

Perl Official Website - https://www.perl.org/

Vous pouvez télécharger la documentation Perl sur le site suivant.

Perl Documentation Website - https://perldoc.perl.org

Installer Perl

La distribution Perl est disponible pour une grande variété de plates-formes. Vous devez télécharger uniquement le code binaire applicable à votre plate-forme et installer Perl.

Si le code binaire de votre plateforme n'est pas disponible, vous avez besoin d'un compilateur C pour compiler le code source manuellement. La compilation du code source offre plus de flexibilité en termes de choix des fonctionnalités dont vous avez besoin dans votre installation.

Voici un bref aperçu de l'installation de Perl sur différentes plates-formes.

Installation Unix et Linux

Voici les étapes simples pour installer Perl sur une machine Unix / Linux.

  • Ouvrez un navigateur Web et accédez à https://www.perl.org/get.html.

  • Suivez le lien pour télécharger le code source compressé disponible pour Unix / Linux.

  • Télécharger perl-5.x.y.tar.gz file et exécutez les commandes suivantes à l'invite $.

$tar -xzf perl-5.x.y.tar.gz
$cd perl-5.x.y $./Configure -de
$make $make test
$make install

NOTE - Ici $ est une invite Unix dans laquelle vous tapez votre commande, assurez-vous donc de ne pas taper $ en tapant les commandes mentionnées ci-dessus.

Cela installera Perl dans un emplacement standard / usr / local / bin et ses bibliothèques sont installées dans / usr / local / lib / perlXX , où XX est la version de Perl que vous utilisez.

Il faudra un certain temps pour compiler le code source après avoir émis le makecommander. Une fois l'installation terminée, vous pouvez émettreperl -và l'invite $ pour vérifier l'installation de perl. Si tout va bien, alors il affichera un message comme nous l'avons montré ci-dessus.

Installation de Windows

Voici les étapes pour installer Perl sur une machine Windows.

  • Suivez le lien pour l'installation de Strawberry Perl sur Windows http://strawberryperl.com

  • Téléchargez la version 32 bits ou 64 bits de l'installation.

  • Exécutez le fichier téléchargé en double-cliquant dessus dans l'Explorateur Windows. Cela fait apparaître l'assistant d'installation de Perl, qui est vraiment facile à utiliser. Acceptez simplement les paramètres par défaut, attendez que l'installation soit terminée et vous êtes prêt à démarrer!

Installation sur Macintosh

Pour créer votre propre version de Perl, vous aurez besoin de «make», qui fait partie des outils de développement Apples généralement fournis avec les DVD d'installation de Mac OS. Vous n'avez pas besoin de la dernière version de Xcode (qui est désormais facturée) pour installer make.

Voici les étapes simples pour installer Perl sur une machine Mac OS X.

  • Ouvrez un navigateur Web et accédez à https://www.perl.org/get.html.

  • Suivez le lien pour télécharger le code source compressé disponible pour Mac OS X.

  • Télécharger perl-5.x.y.tar.gz file et exécutez les commandes suivantes à l'invite $.

$tar -xzf perl-5.x.y.tar.gz
$cd perl-5.x.y $./Configure -de
$make $make test
$make install

Cela installera Perl dans un emplacement standard / usr / local / bin et ses bibliothèques sont installées dans / usr / local / lib / perlXX , où XX est la version de Perl que vous utilisez.

Exécuter Perl

Voici les différentes manières de démarrer Perl.

Interprète interactif

Vous pouvez entrer perlet commencez immédiatement à coder dans l'interpréteur interactif en le démarrant à partir de la ligne de commande. Vous pouvez le faire depuis Unix, DOS ou tout autre système, qui vous fournit un interpréteur de ligne de commande ou une fenêtre shell.

$perl  -e <perl code>           # Unix/Linux

or 

C:>perl -e <perl code>          # Windows/DOS

Voici la liste de toutes les options de ligne de commande disponibles -

Sr.No. Option et description
1

-d[:debugger]

Exécute le programme sous le débogueur

2

-Idirectory

Spécifie le répertoire @ INC / # include

3

-T

Active les contrôles de saleté

4

-t

Active les avertissements d'altération

5

-U

Permet des opérations dangereuses

6

-w

Active de nombreux avertissements utiles

sept

-W

Active tous les avertissements

8

-X

Désactive tous les avertissements

9

-e program

Exécute le script Perl envoyé en tant que programme

dix

file

Exécute le script Perl à partir d'un fichier donné

Script depuis la ligne de commande

Un script Perl est un fichier texte, qui contient du code Perl et il peut être exécuté en ligne de commande en appelant l'interpréteur sur votre application, comme dans l'exemple suivant -

$perl  script.pl          # Unix/Linux

or 

C:>perl script.pl         # Windows/DOS

Environnement de développement intégré

Vous pouvez également exécuter Perl à partir d'un environnement d'interface utilisateur graphique (GUI). Tout ce dont vous avez besoin est une application GUI sur votre système qui prend en charge Perl. Vous pouvez télécharger Padre, l'IDE Perl . Vous pouvez également utiliser Eclipse Plugin EPIC - Perl Editor et IDE pour Eclipse si vous êtes familier avec Eclipse.

Avant de passer au chapitre suivant, assurez-vous que votre environnement est correctement configuré et fonctionne parfaitement. Si vous ne parvenez pas à configurer correctement l'environnement, vous pouvez demander l'aide de votre administrateur système.

Tous les exemples donnés dans les chapitres suivants ont été exécutés avec la version v5.16.2 disponible sur la saveur CentOS de Linux.

Perl emprunte la syntaxe et les concepts à de nombreux langages: awk, sed, C, Bourne Shell, Smalltalk, Lisp et même l'anglais. Cependant, il existe des différences certaines entre les langues. Ce chapitre est conçu pour vous familiariser rapidement avec la syntaxe attendue en Perl.

Un programme Perl se compose d'une séquence de déclarations et d'instructions, qui vont du haut vers le bas. Les boucles, sous-programmes et autres structures de contrôle vous permettent de vous déplacer dans le code. Chaque instruction simple doit se terminer par un point-virgule (;).

Perl est un langage de forme libre: vous pouvez le formater et l'indenter comme vous le souhaitez. Les espaces blancs servent principalement à séparer les jetons, contrairement à des langages comme Python où il est une partie importante de la syntaxe, ou Fortran où il est immatériel.

Premier programme Perl

Programmation en mode interactif

Vous pouvez utiliser l'interpréteur Perl avec -eoption en ligne de commande, qui vous permet d'exécuter des instructions Perl à partir de la ligne de commande. Essayons quelque chose à l'invite $ comme suit -

$perl -e 'print "Hello World\n"'

Cette exécution produira le résultat suivant -

Hello, world

Programmation en mode script

En supposant que vous êtes déjà sur $ prompt, ouvrons un fichier texte hello.pl en utilisant l'éditeur vi ou vim et mettons les lignes suivantes dans votre fichier.

#!/usr/bin/perl

# This will print "Hello, World"
print "Hello, world\n";

Ici /usr/bin/perlest le binaire de l'interpréteur perl. Avant d'exécuter votre script, assurez-vous de changer le mode du fichier de script et de donner le privilège d'exécution, généralement un paramètre de 0755 fonctionne parfaitement et enfin vous exécutez le script ci-dessus comme suit -

$chmod 0755 hello.pl $./hello.pl

Cette exécution produira le résultat suivant -

Hello, world

Vous pouvez utiliser des parenthèses pour les arguments des fonctions ou les omettre selon vos goûts personnels. Ils ne sont nécessaires qu'occasionnellement pour clarifier les questions de préséance. Les deux instructions suivantes produisent le même résultat.

print("Hello, world\n");
print "Hello, world\n";

Extension de fichier Perl

Un script Perl peut être créé à l'intérieur de n'importe quel programme normal d'éditeur de texte simple. Il existe plusieurs programmes disponibles pour chaque type de plate-forme. Il existe de nombreux programmes conçus pour les programmeurs disponibles en téléchargement sur le Web.

En tant que convention Perl, un fichier Perl doit être enregistré avec une extension de fichier .pl ou .PL pour être reconnu comme un script Perl fonctionnel. Les noms de fichier peuvent contenir des chiffres, des symboles et des lettres mais ne doivent pas contenir d'espace. Utilisez un trait de soulignement (_) à la place des espaces.

Commentaires en Perl

Les commentaires dans n'importe quel langage de programmation sont des amis des développeurs. Les commentaires peuvent être utilisés pour rendre le programme convivial et ils sont simplement ignorés par l'interpréteur sans affecter la fonctionnalité du code. Par exemple, dans le programme ci-dessus, une ligne commençant par hash# est un commentaire.

Dire simplement que les commentaires en Perl commencent par un symbole de hachage et vont à la fin de la ligne -

# This is a comment in perl

Les lignes commençant par = sont interprétées comme le début d'une section de la documentation intégrée (pod), et toutes les lignes suivantes jusqu'au prochain = cut sont ignorées par le compilateur. Voici l'exemple -

#!/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

Cela produira le résultat suivant -

Hello, world

Espaces blancs en Perl

Un programme Perl ne se soucie pas des espaces. Le programme suivant fonctionne parfaitement bien -

#!/usr/bin/perl

print       "Hello, world\n";

Mais si des espaces sont à l'intérieur des chaînes entre guillemets, ils seront alors imprimés tels quels. Par exemple -

#!/usr/bin/perl

# This would print with a line break in the middle
print "Hello
          world\n";

Cela produira le résultat suivant -

Hello
          world

Tous les types d'espaces tels que les espaces, les tabulations, les retours à la ligne, etc. sont équivalents pour l'interpréteur lorsqu'ils sont utilisés en dehors des guillemets. Une ligne ne contenant que des espaces, éventuellement avec un commentaire, est appelée ligne vierge et Perl l'ignore totalement.

Citations simples et doubles en Perl

Vous pouvez utiliser des guillemets doubles ou simples autour des chaînes littérales comme suit -

#!/usr/bin/perl

print "Hello, world\n";
print 'Hello, world\n';

Cela produira le résultat suivant -

Hello, world
Hello, world\n$

Il existe une différence importante entre les guillemets simples et doubles. Seulement des guillemets doublesinterpolatevariables et caractères spéciaux tels que les retours à la ligne \ n, tandis que les guillemets simples n'interpolent aucune variable ou caractère spécial. Vérifiez ci-dessous l'exemple où nous utilisons $ a comme variable pour stocker une valeur et imprimer plus tard cette valeur -

#!/usr/bin/perl

$a = 10; print "Value of a = $a\n";
print 'Value of a = $a\n';

Cela produira le résultat suivant -

Value of a = 10
Value of a = $a\n$

Documents "Ici"

Vous pouvez stocker ou imprimer du texte multiligne avec un grand confort. Même vous pouvez utiliser des variables dans le document "ici". Voici une syntaxe simple, vérifiez bien qu'il ne doit pas y avoir d'espace entre le << et l'identifiant.

Un identifiant peut être un simple mot ou un texte cité comme nous avons utilisé EOF ci-dessous. Si l'identifiant est cité, le type de devis que vous utilisez détermine le traitement du texte à l'intérieur du document ici, tout comme pour les citations régulières. Un identifiant sans guillemets fonctionne comme des guillemets doubles.

#!/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";

Cela produira le résultat suivant -

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

Échapper à des personnages

Perl utilise la barre oblique inverse (\) pour échapper à tout type de caractère qui pourrait interférer avec notre code. Prenons un exemple où nous voulons imprimer des guillemets doubles et le signe $ -

#!/usr/bin/perl

$result = "This is \"number\""; print "$result\n";
print "\$result\n";

Cela produira le résultat suivant -

This is "number"
$result

Identificateurs Perl

Un identifiant Perl est un nom utilisé pour identifier une variable, une fonction, une classe, un module ou un autre objet. Un nom de variable Perl commence par $, @ ou% suivi de zéro ou plusieurs lettres, traits de soulignement et chiffres (0 à 9).

Perl n'autorise pas les caractères de ponctuation tels que @, $ et% dans les identificateurs. Perl est uncase sensitivelangage de programmation. Donc$Manpower et $manpower sont deux identifiants différents en Perl.

Perl est un langage mal typé et il n'est pas nécessaire de spécifier un type pour vos données lors de l'utilisation dans votre programme. L'interpréteur Perl choisira le type en fonction du contexte des données elles-mêmes.

Perl a trois types de données de base: les scalaires, les tableaux de scalaires et les hachages de scalaires, également appelés tableaux associatifs. Voici un petit détail sur ces types de données.

Sr.No. Types et description
1

Scalar

Les scalaires sont des variables simples. Ils sont précédés d'un signe dollar ($). Un scalaire est un nombre, une chaîne ou une référence. Une référence est en fait l'adresse d'une variable, que nous verrons dans les prochains chapitres.

2

Arrays

Les tableaux sont des listes ordonnées de scalaires auxquelles vous accédez avec un index numérique, qui commence par 0. Ils sont précédés d'un signe «at» (@).

3

Hashes

Les hachages sont des ensembles non ordonnés de paires clé / valeur auxquels vous accédez en utilisant les clés comme indices. Ils sont précédés d'un signe de pourcentage (%).

Littéraux numériques

Perl stocke tous les nombres en interne sous forme d'entiers signés ou de valeurs à virgule flottante double précision. Les littéraux numériques sont spécifiés dans l'un des formats à virgule flottante ou entier suivants -

Type Valeur
Entier 1234
Entier négatif -100
Point flottant 2000
Notation scientifique 16.12E14
Hexadécimal 0xffff
Octal 0577

Littéraux de chaîne

Les chaînes sont des séquences de caractères. Ce sont généralement des valeurs alphanumériques délimitées par des guillemets simples (') ou doubles ("). Ils fonctionnent un peu comme les guillemets shell UNIX où vous pouvez utiliser des chaînes entre guillemets simples et des chaînes entre guillemets doubles.

Les chaînes littérales entre guillemets autorisent l'interpolation de variables, contrairement aux chaînes entre guillemets simples. Il y a certains caractères lorsqu'ils sont précédés d'une barre oblique inverse, ont une signification particulière et ils sont utilisés pour représenter comme une nouvelle ligne (\ n) ou une tabulation (\ t).

Vous pouvez intégrer des nouvelles lignes ou l'une des séquences d'échappement suivantes directement dans vos chaînes entre guillemets -

Séquence d'échappement Sens
\\ Barre oblique inverse
\ ' Simple citation
\ " Double citation
\une Alerte ou cloche
\ b Retour arrière
\F Saut de formulaire
\ n Nouvelle ligne
\ r Retour chariot
\ t Onglet horizontal
\ v Onglet vertical
\ 0nn Crée des nombres au format octal
\ xnn Crée des nombres au format hexideciamal
\ cX Contrôle les caractères, x peut être n'importe quel caractère
\ u Force le caractère suivant en majuscule
\ l Force le caractère suivant en minuscules
\ U Force tous les caractères suivants en majuscules
\ L Force tous les caractères suivants en minuscules
\ Q Barre oblique inverse tous les caractères non alphanumériques suivants
\ E Fin \ U, \ L ou \ Q

Exemple

Voyons à nouveau comment les chaînes se comportent avec des guillemets simples et doubles. Ici, nous utiliserons les échappements de chaîne mentionnés dans le tableau ci-dessus et utiliserons la variable scalaire pour attribuer des valeurs de chaîne.

#!/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";

Cela produira le résultat suivant -

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

Les variables sont les emplacements de mémoire réservés pour stocker les valeurs. Cela signifie que lorsque vous créez une variable, vous réservez de l'espace en mémoire.

En fonction du type de données d'une variable, l'interpréteur alloue de la mémoire et décide de ce qui peut être stocké dans la mémoire réservée. Par conséquent, en attribuant différents types de données aux variables, vous pouvez stocker des entiers, des décimales ou des chaînes dans ces variables.

Nous avons appris que Perl a les trois types de données de base suivants -

  • Scalars
  • Arrays
  • Hashes

En conséquence, nous allons utiliser trois types de variables en Perl. UNEscalarvariable précédera d'un signe dollar ($) et pourra stocker un nombre, une chaîne ou une référence. Unarrayvariable précédera du signe @ et stockera des listes ordonnées de scalaires. Enfin, leHash variable précédera du signe% et sera utilisée pour stocker des ensembles de paires clé / valeur.

Perl maintient chaque type de variable dans un espace de noms séparé. Vous pouvez donc, sans crainte de conflit, utiliser le même nom pour une variable scalaire, un tableau ou un hachage. Cela signifie que $ foo et @foo sont deux variables différentes.

Créer des variables

Les variables Perl n'ont pas besoin d'être explicitement déclarées pour réserver de l'espace mémoire. La déclaration se produit automatiquement lorsque vous affectez une valeur à une variable. Le signe égal (=) est utilisé pour attribuer des valeurs aux variables.

Notez qu'il est obligatoire de déclarer une variable avant de l'utiliser si nous utilisons use strict déclaration dans notre programme.

L'opérande à gauche de l'opérateur = est le nom de la variable et l'opérande à droite de l'opérateur = est la valeur stockée dans la variable. Par exemple -

$age = 25;             # An integer assignment
$name = "John Paul"; # A string $salary = 1445.50;     # A floating point

Ici, 25, «John Paul» et 1445,50 sont les valeurs affectées respectivement aux variables $ age , $ name et $ salaire . Nous verrons bientôt comment attribuer des valeurs aux tableaux et aux hachages.

Variables scalaires

Un scalaire est une seule unité de données. Ces données peuvent être un nombre entier, une virgule flottante, un caractère, une chaîne, un paragraphe ou une page Web entière. Dire simplement que cela pourrait être n'importe quoi, mais une seule chose.

Voici un exemple simple d'utilisation de variables scalaires -

#!/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";

Cela produira le résultat suivant -

Age = 25
Name = John Paul
Salary = 1445.5

Variables de tableau

Un tableau est une variable qui stocke une liste ordonnée de valeurs scalaires. Les variables de tableau sont précédées d'un signe «at» (@). Pour faire référence à un seul élément d'un tableau, vous utiliserez le signe dollar ($) avec le nom de la variable suivi de l'index de l'élément entre crochets.

Voici un exemple simple d'utilisation de variables de tableau -

#!/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";

Ici, nous avons utilisé le signe d'échappement (\) avant le signe $ juste pour l'imprimer. Les autres Perl le comprendront comme une variable et afficheront sa valeur. Une fois exécuté, cela produira le résultat suivant -

$ages[0] = 25
$ages[1] = 30 $ages[2] = 40
$names[0] = John Paul $names[1] = Lisa
$names[2] = Kumar

Variables de hachage

Un hachage est un ensemble de key/valuepaires. Les variables de hachage sont précédées d'un signe de pourcentage (%). Pour faire référence à un seul élément d'un hachage, vous utiliserez le nom de la variable de hachage suivi de la «clé» associée à la valeur entre accolades.

Voici un exemple simple d'utilisation de variables de hachage -

#!/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";

Cela produira le résultat suivant -

$data{'John Paul'} = 45
$data{'Lisa'} = 30 $data{'Kumar'} = 40

Contexte variable

Perl traite la même variable différemment en fonction du contexte, c'est-à-dire de la situation où une variable est utilisée. Vérifions l'exemple suivant -

#!/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";

Cela produira le résultat suivant -

Given names are : John Paul Lisa Kumar
Number of names are : 3

Ici, @names est un tableau, qui a été utilisé dans deux contextes différents. Nous l'avons d'abord copié dans un autre tableau, c'est-à-dire une liste, donc il a renvoyé tous les éléments en supposant que le contexte est un contexte de liste. Ensuite, nous avons utilisé le même tableau et essayé de stocker ce tableau dans un scalaire, donc dans ce cas, il n'a renvoyé que le nombre d'éléments dans ce tableau en supposant que le contexte est un contexte scalaire. Le tableau suivant répertorie les différents contextes -

Sr.No. Contexte et description
1

Scalar

L'affectation à une variable scalaire évalue le côté droit dans un contexte scalaire.

2

List

L'affectation à un tableau ou à un hachage évalue le côté droit dans un contexte de liste.

3

Boolean

Le contexte booléen est simplement n'importe quel endroit où une expression est évaluée pour voir si elle est vraie ou fausse.

4

Void

Ce contexte ne se soucie pas seulement de la valeur de retour, il ne veut même pas de valeur de retour.

5

Interpolative

Ce contexte ne se produit que dans des guillemets ou des choses qui fonctionnent comme des guillemets.

Un scalaire est une seule unité de données. Ces données peuvent être un nombre entier, une virgule flottante, un caractère, une chaîne, un paragraphe ou une page Web entière.

Voici un exemple simple d'utilisation de variables scalaires -

#!/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";

Cela produira le résultat suivant -

Age = 25
Name = John Paul
Salary = 1445.5

Scalaires numériques

Un scalaire est le plus souvent un nombre ou une chaîne. L'exemple suivant montre l'utilisation de divers types de scalaires numériques -

#!/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";

Cela produira le résultat suivant -

integer = 200
negative = -300
floating = 200.34
bigfloat = -1.2e-23
octal = 255
hexa = 255

Scalaires à cordes

L'exemple suivant montre l'utilisation de divers types de scalaires de chaîne. Notez la différence entre les chaînes entre guillemets simples et les chaînes entre guillemets doubles -

#!/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";

Cela produira le résultat suivant -

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

Opérations scalaires

Vous verrez un détail des différents opérateurs disponibles en Perl dans un chapitre séparé, mais ici nous allons lister quelques opérations numériques et de chaîne.

#!/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";

Cela produira le résultat suivant -

str = helloworld
num = 15
mul = 20
mix = helloworld15

Chaînes multilignes

Si vous souhaitez introduire des chaînes multilignes dans vos programmes, vous pouvez utiliser les guillemets simples standard comme ci-dessous -

#!/usr/bin/perl

$string = 'This is a multiline string'; print "$string\n";

Cela produira le résultat suivant -

This is
a multiline
string

Vous pouvez également utiliser la syntaxe du document "ici" pour stocker ou imprimer des multilignes comme ci-dessous -

#!/usr/bin/perl

print <<EOF;
This is
a multiline
string
EOF

Cela produira également le même résultat -

This is
a multiline
string

Cordes en V

Un littéral de la forme v1.20.300.4000 est analysé comme une chaîne composée de caractères avec les ordinaux spécifiés. Cette forme est connue sous le nom de chaînes v.

Une chaîne V fournit une manière alternative et plus lisible de construire des chaînes, plutôt que d'utiliser la forme d'interpolation un peu moins lisible "\ x {1} \ x {14} \ x {12c} \ x {fa0}".

Il s'agit de tout littéral commençant par av et suivi d'un ou plusieurs éléments séparés par des points. Par exemple -

#!/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";

Cela produira également le même résultat -

smile = ☺
foo = foo
martin = Martin
Wide character in print at main.pl line 7.

Littéraux spéciaux

Jusqu'à présent, vous devez avoir une idée des scalaires de chaîne et de son opération de concaténation et d'interpolation. Alors laissez-moi vous parler de trois littéraux spéciaux __FILE__, __LINE__ et __PACKAGE__ représentent le nom de fichier actuel, le numéro de ligne et le nom du package à ce stade de votre programme.

Ils ne peuvent être utilisés que comme jetons séparés et ne seront pas interpolés en chaînes. Vérifiez l'exemple ci-dessous -

#!/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";

Cela produira le résultat suivant -

File name hello.pl
Line Number 4
Package main
__FILE__ __LINE__ __PACKAGE__

Un tableau est une variable qui stocke une liste ordonnée de valeurs scalaires. Les variables de tableau sont précédées d'un signe «at» (@). Pour faire référence à un seul élément d'un tableau, vous utiliserez le signe dollar ($) avec le nom de la variable suivi de l'index de l'élément entre crochets.

Voici un exemple simple d'utilisation des variables de tableau -

#!/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";

Ici, nous avons utilisé le signe d'échappement (\) avant le signe $ juste pour l'imprimer. Les autres Perl le comprendront comme une variable et afficheront sa valeur. Une fois exécuté, cela produira le résultat suivant -

$ages[0] = 25 $ages[1] = 30
$ages[2] = 40 $names[0] = John Paul
$names[1] = Lisa $names[2] = Kumar

En Perl, les termes List et Array sont souvent utilisés comme s'ils étaient interchangeables. Mais la liste contient les données et le tableau est la variable.

Création de tableaux

Les variables de tableau sont précédées du signe @ et sont remplies à l'aide de parenthèses ou de l'opérateur qw. Par exemple -

@array = (1, 2, 'Hello');
@array = qw/This is an array/;

La deuxième ligne utilise l'opérateur qw //, qui renvoie une liste de chaînes, séparant la chaîne délimitée par un espace blanc. Dans cet exemple, cela conduit à un tableau à quatre éléments; le premier élément est «this» et le dernier (quatrième) est «array». Cela signifie que vous pouvez utiliser différentes lignes comme suit -

@days = qw/Monday
Tuesday
...
Sunday/;

Vous pouvez également remplir un tableau en affectant chaque valeur individuellement comme suit -

$array[0] = 'Monday'; ... $array[6] = 'Sunday';

Accès aux éléments de la baie

Lors de l'accès à des éléments individuels à partir d'un tableau, vous devez faire précéder la variable d'un signe dollar ($), puis ajouter l'index de l'élément entre crochets après le nom de la variable. Par exemple -

#!/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";

Cela produira le résultat suivant -

Mon
Tue
Wed
Sun
Sun
Mon

Les indices de tableau commencent à zéro, donc pour accéder au premier élément, vous devez donner 0 comme index. Vous pouvez également donner un index négatif, auquel cas vous sélectionnez l'élément à partir de la fin, plutôt que du début, du tableau. Cela signifie ce qui suit -

print $days[-1]; # outputs Sun
print $days[-7]; # outputs Mon

Tableaux de nombres séquentiels

Perl propose un raccourci pour les nombres et les lettres séquentiels. Plutôt que de taper chaque élément en comptant jusqu'à 100 par exemple, nous pouvons faire quelque chose comme suit -

#!/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

Ici, le double point (..) est appelé range operator. Cela produira le résultat suivant -

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

Taille du tableau

La taille d'un tableau peut être déterminée en utilisant le contexte scalaire sur le tableau - la valeur retournée sera le nombre d'éléments dans le tableau -

@array = (1,2,3);
print "Size: ",scalar @array,"\n";

La valeur renvoyée sera toujours la taille physique du tableau, et non le nombre d'éléments valides. Vous pouvez démontrer cela, et la différence entre scalaire @array et $ # array, en utilisant ce fragment est la suivante -

#!/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";

Cela produira le résultat suivant -

Size: 51
Max Index: 50

Il n'y a que quatre éléments dans le tableau qui contiennent des informations, mais le tableau compte 51 éléments, avec un indice le plus élevé de 50.

Ajout et suppression d'éléments dans un tableau

Perl fournit un certain nombre de fonctions utiles pour ajouter et supprimer des éléments dans un tableau. Vous vous demandez peut-être qu'est-ce qu'une fonction? Jusqu'à présent, vous avez utiliséprintfonction pour imprimer diverses valeurs. De même, il existe diverses autres fonctions ou parfois appelées sous-routines, qui peuvent être utilisées pour diverses autres fonctionnalités.

Sr.No. Types et description
1

push @ARRAY, LIST

Pousse les valeurs de la liste à la fin du tableau.

2

pop @ARRAY

Saute et renvoie la dernière valeur du tableau.

3

shift @ARRAY

Décale la première valeur du tableau et la renvoie, raccourcissant le tableau de 1 et déplaçant tout vers le bas.

4

unshift @ARRAY, LIST

Ajoute la liste au début du tableau et renvoie le nombre d'éléments dans le nouveau tableau.

#!/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";

Cela produira le résultat suivant -

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

Trancher les éléments du tableau

Vous pouvez également extraire une «tranche» d'un tableau - c'est-à-dire que vous pouvez sélectionner plusieurs éléments d'un tableau afin de produire un autre tableau.

#!/usr/bin/perl

@days = qw/Mon Tue Wed Thu Fri Sat Sun/;

@weekdays = @days[3,4,5];

print "@weekdays\n";

Cela produira le résultat suivant -

Thu Fri Sat

La spécification d'une tranche doit avoir une liste d'indices valides, positifs ou négatifs, chacun séparé par une virgule. Pour la vitesse, vous pouvez également utiliser le.. opérateur de plage -

#!/usr/bin/perl

@days = qw/Mon Tue Wed Thu Fri Sat Sun/;

@weekdays = @days[3..5];

print "@weekdays\n";

Cela produira le résultat suivant -

Thu Fri Sat

Remplacement des éléments de la baie

Nous allons maintenant introduire une autre fonction appelée splice(), qui a la syntaxe suivante -

splice @ARRAY, OFFSET [ , LENGTH [ , LIST ] ]

Cette fonction supprimera les éléments de @ARRAY désignés par OFFSET et LENGTH, et les remplacera par LIST, si spécifié. Enfin, il renvoie les éléments supprimés du tableau. Voici l'exemple -

#!/usr/bin/perl

@nums = (1..20);
print "Before - @nums\n";

splice(@nums, 5, 5, 21..25); 
print "After - @nums\n";

Cela produira le résultat suivant -

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

Ici, le remplacement proprement dit commence par le 6ème chiffre après que cinq éléments sont ensuite remplacés de 6 à 10 par les numéros 21, 22, 23, 24 et 25.

Transformer des chaînes en tableaux

Examinons une autre fonction appelée split(), qui a la syntaxe suivante -

split [ PATTERN [ , EXPR [ , LIMIT ] ] ]

Cette fonction divise une chaîne en un tableau de chaînes et la renvoie. Si LIMIT est spécifié, se divise en au plus ce nombre de champs. Si PATTERN est omis, se divise sur des espaces. Voici l'exemple -

#!/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

Cela produira le résultat suivant -

Roses
Michael

Transformer les tableaux en chaînes

Nous pouvons utiliser le join()pour rejoindre les éléments du tableau et former une longue chaîne scalaire. Cette fonction a la syntaxe suivante -

join EXPR, LIST

Cette fonction joint les chaînes distinctes de LIST en une seule chaîne avec des champs séparés par la valeur de EXPR et renvoie la chaîne. Voici l'exemple -

#!/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";

Cela produira le résultat suivant -

Rain-Drops-On-Roses-And-Whiskers-On-Kittens
Larry,David,Roger,Ken,Michael,Tom

Tri des tableaux

le sort()La fonction trie chaque élément d'un tableau selon les normes numériques ASCII. Cette fonction a la syntaxe suivante -

sort [ SUBROUTINE ] LIST

Cette fonction trie la LISTE et renvoie la valeur du tableau trié. Si SUBROUTINE est spécifié, la logique spécifiée à l'intérieur du SUBTROUTINE est appliquée lors du tri des éléments.

#!/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";

Cela produira le résultat suivant -

Before: pizza steak chicken burgers
After: burgers chicken pizza steak

Veuillez noter que le tri est effectué en fonction de la valeur numérique ASCII des mots. La meilleure option consiste donc à d'abord transformer chaque élément du tableau en lettres minuscules, puis à exécuter la fonction de tri.

Fusion de tableaux

Étant donné qu'un tableau n'est qu'une séquence de valeurs séparées par des virgules, vous pouvez les combiner comme indiqué ci-dessous -

#!/usr/bin/perl

@numbers = (1,3,(4,5,6));

print "numbers = @numbers\n";

Cela produira le résultat suivant -

numbers = 1 3 4 5 6

Les tableaux intégrés font simplement partie du tableau principal comme indiqué ci-dessous -

#!/usr/bin/perl

@odd = (1,3,5);
@even = (2, 4, 6);

@numbers = (@odd, @even);

print "numbers = @numbers\n";

Cela produira le résultat suivant -

numbers = 1 3 5 2 4 6

Sélection d'éléments dans les listes

La notation de liste est identique à celle des tableaux. Vous pouvez extraire un élément d'un tableau en ajoutant des crochets à la liste et en donnant un ou plusieurs indices -

#!/usr/bin/perl

$var = (5,4,3,2,1)[4]; print "value of var = $var\n"

Cela produira le résultat suivant -

value of var = 1

De même, nous pouvons extraire des tranches, mais sans avoir besoin d'un caractère @ de début -

#!/usr/bin/perl

@list = (5,4,3,2,1)[1..3];

print "Value of list = @list\n";

Cela produira le résultat suivant -

Value of list = 4 3 2

Un hachage est un ensemble de key/valuepaires. Les variables de hachage sont précédées d'un signe de pourcentage (%). Pour faire référence à un seul élément d'un hachage, vous utiliserez le nom de la variable de hachage précédé d'un signe «$» et suivi de la «clé» associée à la valeur entre accolades.

Voici un exemple simple d'utilisation des variables de hachage -

#!/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";

Cela produira le résultat suivant -

$data{'John Paul'} = 45
$data{'Lisa'} = 30 $data{'Kumar'} = 40

Créer des hachages

Les hachages sont créés de l'une des deux manières suivantes. Dans la première méthode, vous attribuez une valeur à une clé nommée sur une base un par un -

$data{'John Paul'} = 45; $data{'Lisa'} = 30;
$data{'Kumar'} = 40;

Dans le second cas, vous utilisez une liste, qui est convertie en prenant des paires individuelles de la liste: le premier élément de la paire est utilisé comme clé, et le second, comme valeur. Par exemple -

%data = ('John Paul', 45, 'Lisa', 30, 'Kumar', 40);

Pour plus de clarté, vous pouvez utiliser => comme alias pour, pour indiquer les paires clé / valeur comme suit -

%data = ('John Paul' => 45, 'Lisa' => 30, 'Kumar' => 40);

Voici une autre variante du formulaire ci-dessus, regardez-la, ici toutes les clés ont été précédées d'un tiret (-) et aucune citation n'est requise autour d'elles -

%data = (-JohnPaul => 45, -Lisa => 30, -Kumar => 40);

Mais il est important de noter qu'il n'y a qu'un seul mot, c'est-à-dire que les clés sans espaces ont été utilisées dans cette forme de formation de hachage et si vous construisez votre hachage de cette façon, les clés seront accessibles en utilisant un trait d'union uniquement comme indiqué ci-dessous.

$val = %data{-JohnPaul}
$val = %data{-Lisa}

Accéder aux éléments de hachage

Lors de l'accès à des éléments individuels à partir d'un hachage, vous devez faire précéder la variable d'un signe dollar ($), puis ajouter la clé d'élément entre accolades après le nom de la variable. Par exemple -

#!/usr/bin/perl

%data = ('John Paul' => 45, 'Lisa' => 30, 'Kumar' => 40);

print "$data{'John Paul'}\n"; print "$data{'Lisa'}\n";
print "$data{'Kumar'}\n";

Cela produira le résultat suivant -

45
30
40

Extraction de tranches

Vous pouvez extraire des tranches d'un hachage tout comme vous pouvez extraire des tranches d'un tableau. Vous devrez utiliser le préfixe @ pour que la variable stocke la valeur renvoyée car ce sera une liste de valeurs -

#!/uer/bin/perl


%data = (-JohnPaul => 45, -Lisa => 30, -Kumar => 40);

@array = @data{-JohnPaul, -Lisa};

print "Array : @array\n";

Cela produira le résultat suivant -

Array : 45 30

Extraction de clés et de valeurs

Vous pouvez obtenir une liste de toutes les clés d'un hachage en utilisant keys fonction, qui a la syntaxe suivante -

keys %HASH

Cette fonction renvoie un tableau de toutes les clés du hachage nommé. Voici l'exemple -

#!/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";

Cela produira le résultat suivant -

Lisa
John Paul
Kumar

De même, vous pouvez utiliser valuesfonction pour obtenir une liste de toutes les valeurs. Cette fonction a la syntaxe suivante -

values %HASH

Cette fonction renvoie un tableau normal composé de toutes les valeurs du hachage nommé. Voici l'exemple -

#!/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";

Cela produira le résultat suivant -

30
45
40

Vérification de l'existence

Si vous essayez d'accéder à une paire clé / valeur à partir d'un hachage qui n'existe pas, vous obtiendrez normalement le undefinedvalue, et si vous avez activé les avertissements, vous recevrez un avertissement généré au moment de l'exécution. Vous pouvez contourner ce problème en utilisant leexists fonction, qui renvoie true si la clé nommée existe, quelle que soit sa valeur -

#!/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";
}

Ici, nous avons introduit l'instruction IF ... ELSE, que nous étudierons dans un chapitre séparé. Pour l'instant tu supposes juste queif( condition ) partie ne sera exécutée que lorsque la condition donnée est vraie sinon elseune partie sera exécutée. Ainsi, lorsque nous exécutons le programme ci-dessus, il produit le résultat suivant car ici la condition donnée existe ($ data {'Lisa'} renvoie true -

Lisa is 30 years old

Obtenir la taille du hachage

Vous pouvez obtenir la taille, c'est-à-dire le nombre d'éléments à partir d'un hachage en utilisant le contexte scalaire sur des clés ou des valeurs. En disant simplement que vous devez d'abord obtenir un tableau des clés ou des valeurs, vous pouvez ensuite obtenir la taille du tableau comme suit -

#!/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";

Cela produira le résultat suivant -

1 - Hash size: is 3
2 - Hash size: is 3

Ajouter et supprimer des éléments dans les hachages

L'ajout d'une nouvelle paire clé / valeur peut être effectué avec une ligne de code à l'aide d'un opérateur d'affectation simple. Mais pour supprimer un élément du hachage, vous devez utiliserdelete fonction comme indiqué ci-dessous dans l'exemple -

#!/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";

Cela produira le résultat suivant -

1 - Hash size: is 3
2 - Hash size: is 4
3 - Hash size: is 3

Les instructions conditionnelles Perl aident à la prise de décision, qui nécessitent que le programmeur spécifie une ou plusieurs conditions à évaluer ou à tester par le programme, ainsi qu'une ou plusieurs instructions à exécuter si la condition est jugée vraie, et éventuellement d'autres instructions à exécuter si la condition est jugée fausse.

Voici le général d'une structure de prise de décision typique trouvée dans la plupart des langages de programmation -

Le nombre 0, les chaînes '0' et "", la liste vide () et undef sont tous false dans un contexte booléen et toutes les autres valeurs sont true. Négation d'une vraie valeur par! ou not renvoie une valeur fausse spéciale.

Le langage de programmation Perl fournit les types suivants d'instructions conditionnelles.

Sr.No. Déclaration et description
1 si déclaration

Un if statement se compose d'une expression booléenne suivie d'une ou plusieurs instructions.

2 instruction if ... else

Un if statement peut être suivi d'une option else statement.

3 if ... elsif ... else instruction

Un if statement peut être suivi d'une option elsif statement puis par un optionnel else statement.

4 sauf déclaration

Un unless statement se compose d'une expression booléenne suivie d'une ou plusieurs instructions.

5 sauf ... instruction else

Un unless statement peut être suivi d'une option else statement.

6 sauf ... instruction elsif..else

Un unless statement peut être suivi d'une option elsif statement puis par un optionnel else statement.

sept instruction switch

Avec les dernières versions de Perl, vous pouvez utiliser le switchdéclaration. qui permet un moyen simple de comparer une valeur de variable à diverses conditions.

Le ? : Opérateur

Vérifions le conditional operator ? :qui peut être utilisé pour remplacer if...elsedéclarations. Il a la forme générale suivante -

Exp1 ? Exp2 : Exp3;

Où Exp1, Exp2 et Exp3 sont des expressions. Notez l'utilisation et le placement des deux points.

La valeur d'un? expression est déterminée comme ceci: Exp1 est évalué. Si c'est vrai, alors Exp2 est évalué et devient la valeur de l'ensemble? expression. Si Exp1 est faux, Exp3 est évalué et sa valeur devient la valeur de l'expression. Voici un exemple simple utilisant cet opérateur -

#!/usr/local/bin/perl
 
$name = "Ali"; $age = 10;

$status = ($age > 60 )? "A senior citizen" : "Not a senior citizen";

print "$name is - $status\n";

Cela produira le résultat suivant -

Ali is - Not a senior citizen

Il peut arriver que vous deviez exécuter un bloc de code plusieurs fois. En général, les instructions sont exécutées de manière séquentielle: la première instruction d'une fonction est exécutée en premier, suivie de la seconde, et ainsi de suite.

Les langages de programmation fournissent diverses structures de contrôle qui permettent des chemins d'exécution plus compliqués.

Une instruction de boucle nous permet d'exécuter une instruction ou un groupe d'instructions plusieurs fois et voici la forme générale d'une instruction de boucle dans la plupart des langages de programmation -

Le langage de programmation Perl fournit les types de boucle suivants pour gérer les exigences de bouclage.

Sr.No. Type de boucle et description
1 boucle while

Répète une instruction ou un groupe d'instructions tant qu'une condition donnée est vraie. Il teste la condition avant d'exécuter le corps de la boucle.

2 jusqu'à boucle

Répète une déclaration ou un groupe d'instructions jusqu'à ce qu'une condition donnée devienne vraie. Il teste la condition avant d'exécuter le corps de la boucle.

3 pour boucle

Exécute une séquence d'instructions plusieurs fois et abrége le code qui gère la variable de boucle.

4 boucle foreach

La boucle foreach itère sur une valeur de liste normale et définit la variable VAR pour être chaque élément de la liste à son tour.

5 faire ... boucle while

Comme une instruction while, sauf qu'elle teste la condition à la fin du corps de la boucle

6 boucles imbriquées

Vous pouvez utiliser une ou plusieurs boucles à l'intérieur d'une autre boucle while, for ou do.. while.

Déclarations de contrôle de boucle

Les instructions de contrôle de boucle modifient l'exécution de sa séquence normale. Lorsque l'exécution quitte une étendue, tous les objets automatiques qui ont été créés dans cette étendue sont détruits.

Perl prend en charge les instructions de contrôle suivantes. Cliquez sur les liens suivants pour vérifier leurs détails.

Sr.No. Déclaration de contrôle et description
1 déclaration suivante

Force la boucle à ignorer le reste de son corps et à retester immédiatement son état avant de réitérer.

2 Dernière déclaration

Termine l'instruction de boucle et transfère l'exécution à l'instruction immédiatement après la boucle.

3 continue déclaration

Un bloc continue, il est toujours exécuté juste avant que le conditionnel soit sur le point d'être évalué à nouveau.

4 redo déclaration

La commande redo redémarre le bloc de boucle sans réévaluer le conditionnel. Le bloc Continuer, s'il y en a un, n'est pas exécuté.

5 déclaration goto

Perl prend en charge une commande goto avec trois formes: goto label, goto expr et goto & name.

La boucle infinie

Une boucle devient une boucle infinie si une condition ne devient jamais fausse. leforLa boucle est traditionnellement utilisée à cette fin. Puisque aucune des trois expressions qui forment lefor sont obligatoires, vous pouvez créer une boucle sans fin en laissant l'expression conditionnelle vide.

#!/usr/local/bin/perl
 
for( ; ; ) {
   printf "This loop will run forever.\n";
}

Vous pouvez terminer la boucle infinie ci-dessus en appuyant sur les touches Ctrl + C.

Lorsque l'expression conditionnelle est absente, elle est supposée vraie. Vous pouvez avoir une expression d'initialisation et d'incrémentation, mais en tant que programmeur, utilisez plus couramment la construction for (;;) pour signifier une boucle infinie.

Qu'est-ce qu'un opérateur?

Une réponse simple peut être donnée en utilisant l'expression 4 + 5 est égal à 9 . Ici 4 et 5 sont appelés opérandes et + est appelé opérateur. Le langage Perl prend en charge de nombreux types d'opérateurs, mais voici une liste des opérateurs importants et les plus fréquemment utilisés -

  • Opérateurs arithmétiques
  • Opérateurs d'égalité
  • Opérateurs logiques
  • Opérateurs d'affectation
  • Opérateurs au niveau du bit
  • Opérateurs logiques
  • Opérateurs de type devis
  • Opérateurs divers

Jetons un coup d'œil à tous les opérateurs un par un.

Opérateurs arithmétiques Perl

Supposons une variable $a holds 10 and variable $b vaut 20, puis voici les opérateurs arithmatiques Perl -

Afficher l'exemple

Sr.No. Opérateur et description
1

+ ( Addition )

Ajoute des valeurs de chaque côté de l'opérateur

Example - $a + $b donnera 30

2

- (Subtraction)

Soustrait l'opérande de droite de l'opérande de gauche

Example - $a - $b donnera -10

3

* (Multiplication)

Multiplie les valeurs de chaque côté de l'opérateur

Example - $a * $b donnera 200

4

/ (Division)

Divise l'opérande de gauche par l'opérande de droite

Example - $b / $un donnera 2

5

% (Modulus)

Divise l'opérande de gauche par l'opérande de droite et renvoie le reste

Example - $b % $a donnera 0

6

** (Exponent)

Effectue un calcul exponentiel (puissance) sur les opérateurs

Example - $a**$b donnera 10 à la puissance 20

Opérateurs d'égalité Perl

Ceux-ci sont également appelés opérateurs relationnels. Supposons une variable$a holds 10 and variable $b vaut 20 alors, vérifions les opérateurs d'égalité numériques suivants -

Afficher l'exemple

Sr.No. Opérateur et description
1

== (equal to)

Vérifie si la valeur de deux opérandes est égale ou non, si oui, la condition devient vraie.

Example - ($a == $b) n'est pas vrai.

2

!= (not equal to)

Vérifie si la valeur de deux opérandes est égale ou non, si les valeurs ne sont pas égales, la condition devient vraie.

Example - ($a != $b) est vrai.

3

<=>

Vérifie si la valeur de deux opérandes est égale ou non et renvoie -1, 0 ou 1 selon que l'argument de gauche est numériquement inférieur, égal ou supérieur à l'argument de droite.

Example - ($a <=> $b) renvoie -1.

4

> (greater than)

Vérifie si la valeur de l'opérande gauche est supérieure à la valeur de l'opérande droit, si oui, la condition devient vraie.

Example - ($a > $b) n'est pas vrai.

5

< (less than)

Vérifie si la valeur de l'opérande gauche est inférieure à la valeur de l'opérande droit, si oui, la condition devient vraie.

Example - ($a < $b) est vrai.

6

>= (greater than or equal to)

Vérifie si la valeur de l'opérande gauche est supérieure ou égale à la valeur de l'opérande droit, si oui, la condition devient vraie.

Example - ($a >= $b) n'est pas vrai.

sept

<= (less than or equal to)

Vérifie si la valeur de l'opérande gauche est inférieure ou égale à la valeur de l'opérande droit, si oui, la condition devient vraie.

Example - ($a <= $b) est vrai.

Vous trouverez ci-dessous une liste des opérateurs de capitaux propres. Supposons une variable$a holds "abc" and variable $b contient "xyz" alors, vérifions les opérateurs d'égalité de chaîne suivants -

Afficher l'exemple

Sr.No. Opérateur et description
1

lt

Renvoie true si l'argument de gauche est inférieur dans le sens de la chaîne à l'argument de droite.

Example - ($a lt $b) est vrai.

2

gt

Renvoie true si l'argument de gauche est supérieur dans le sens de la chaîne à l'argument de droite.

Example - ($a gt $b) est faux.

3

le

Renvoie true si l'argument de gauche est inférieur ou égal à l'argument de droite dans le sens d'une chaîne.

Example - ($a le $b) est vrai.

4

ge

Renvoie true si l'argument de gauche est supérieur ou égal à l'argument de droite dans le sens d'une chaîne.

Example - ($a ge $b) est faux.

5

eq

Renvoie true si l'argument de gauche est égal dans le sens de la chaîne à l'argument de droite.

Example - ($a eq $b) est faux.

6

ne

Renvoie true si l'argument de gauche n'est pas égal à l'argument de droite dans le sens d'une chaîne.

Example - ($a ne $b) est vrai.

sept

cmp

Renvoie -1, 0 ou 1 selon que l'argument de gauche est inférieur, égal ou supérieur dans le sens de la chaîne à l'argument de droite.

Example - ($a cmp $b) vaut -1.

Opérateurs d'affectation Perl

Supposons une variable $a holds 10 and variable $b contient 20, puis ci-dessous sont les opérateurs d'affectation disponibles en Perl et leur utilisation -

Afficher l'exemple

Sr.No. Opérateur et description
1

=

Opérateur d'affectation simple, attribue des valeurs d'opérandes de droite à l'opérande de gauche

Example - $c = $un + $b will assigned value of $un + $b into $c

2

+=

Ajouter l'opérateur d'affectation ET, il ajoute l'opérande droit à l'opérande gauche et attribue le résultat à l'opérande gauche

Example - $c += $a équivaut à $c = $c + $ a

3

-=

Soustraire l'opérateur d'affectation ET, il soustrait l'opérande droit de l'opérande gauche et attribuer le résultat à l'opérande gauche

Example - $ c - = $a is equivalent to $c = $c - $une

4

*=

Multiplier l'opérateur d'affectation ET, il multiplie l'opérande droit par l'opérande gauche et attribue le résultat à l'opérande gauche

Example - $c *= $a équivaut à $c = $c * $ a

5

/=

Opérateur d'affectation de division ET, il divise l'opérande gauche avec l'opérande droit et affecte le résultat à l'opérande gauche

Example - $ c / = $a is equivalent to $c = $c / $une

6

%=

Opérateur d'assignation de module ET, il prend le module en utilisant deux opérandes et affecte le résultat à l'opérande de gauche

Example - $c %= $a équivaut à $c = $Californie

sept

**=

Opérateur d'affectation exposant ET, effectue un calcul exponentiel (puissance) sur les opérateurs et attribue une valeur à l'opérande de gauche

Example - $c **= $a équivaut à $c = $c ** $ a

Opérateurs binaires Perl

L'opérateur au niveau du bit fonctionne sur les bits et effectue des opérations bit par bit. Supposons si $ a = 60; et $ b = 13; Maintenant au format binaire, ils seront comme suit -

$ a = 0011 1100

$ b = 0000 1101

-----------------

$ a et $ b = 0000 1100

$ a | $ b = 0011 1101

$ a ^ $ b = 0011 0001

~ $ a = 1100 0011

Les opérateurs Bitwise suivants sont pris en charge par le langage Perl, supposons que si $a = 60; and $b = 13

Afficher l'exemple

Sr.No. Opérateur et description
1

&

L'opérateur binaire AND copie un peu le résultat s'il existe dans les deux opérandes.

Example - ($a & $b) donnera 12, soit 0000 1100

2

|

L'opérateur binaire OR copie un peu s'il existe dans l'opérande eather.

Example - ($a | $b) donnera 61 qui est 0011 1101

3

^

L'opérateur XOR binaire copie le bit s'il est défini dans un opérande mais pas dans les deux.

Example - ($a ^ $b) donnera 49 qui est 0011 0001

4

~

L'opérateur de complément des binaires est unaire et a pour effet de «basculer» les bits.

Example - (~ $ a) donnera -61 qui est 1100 0011 en forme de complément à 2 en raison d'un nombre binaire signé.

5

<<

Opérateur de décalage binaire gauche. La valeur des opérandes de gauche est déplacée vers la gauche du nombre de bits spécifié par l'opérande de droite.

Example - $ a << 2 donnera 240 soit 1111 0000

6

>>

Opérateur de décalage binaire vers la droite. La valeur des opérandes de gauche est déplacée vers la droite du nombre de bits spécifié par l'opérande de droite.

Example - $ a >> 2 donnera 15, soit 0000 1111

Opérateurs logiques Perl

Les opérateurs logiques suivants sont pris en charge par le langage Perl. Supposons que la variable $ a soit vraie et que la variable $ b soit fausse alors -

Afficher l'exemple

Sr.No. Opérateur et description
1

and

Opérateur logique ET appelé. Si les deux opérandes sont vrais, la condition devient vraie.

Example - ($ a et $ b) est faux.

2

&&

L'opérateur ET logique de style C copie un peu le résultat s'il existe dans les deux opérandes.

Example - ($ a && $ b) est faux.

3

or

Opérateur OU logique appelé. Si l'un des deux opérandes est différent de zéro, la condition devient vraie.

Example - ($ a ou $ b) est vrai.

4

||

L'opérateur OU logique de style C copie un peu s'il existe dans l'opérande eather.

Example - ($ a || $ b) est vrai.

5

not

Opérateur PAS logique appelé. Utilisez pour inverser l'état logique de son opérande. Si une condition est vraie, l'opérateur NOT logique rendra faux.

Example - not ($ a et $ b) est vrai.

Opérateurs de type devis

Les opérateurs de type Quote suivants sont pris en charge par le langage Perl. Dans le tableau suivant, un {} représente toute paire de délimiteurs que vous choisissez.

Afficher l'exemple

Sr.No. Opérateur et description
1

q{ }

Entoure une chaîne de guillemets simples

Example - q {abcd} donne 'abcd'

2

qq{ }

Entoure une chaîne de guillemets doubles

Example - qq {abcd} donne "abcd"

3

qx{ }

Entoure une chaîne avec des guillemets inversés

Example - qx {abcd} donne `abcd`

Opérateurs divers

Les opérateurs suivants sont pris en charge par le langage Perl. Supposons que la variable a vaut 10 et la variable b vaut 20 alors -

Afficher l'exemple

Sr.No. Opérateur et description
1

.

L'opérateur binaire dot (.) Concatène deux chaînes.

Example - Si $ a = "abc", $b = "def" then $a. $ b donnera "abcdef"

2

x

L'opérateur de répétition x renvoie une chaîne constituée de l'opérande gauche répété le nombre de fois spécifié par l'opérande droit.

Example - ('-' x 3) donnera ---.

3

..

L'opérateur de plage .. renvoie une liste de valeurs comptées (par unités) de la valeur de gauche à la valeur de droite

Example - (2..5) donnera (2, 3, 4, 5)

4

++

L'opérateur d'incrémentation automatique augmente la valeur entière de un

Example - $ a ++ donnera 11

5

--

L'opérateur de décrémentation automatique diminue la valeur entière de un

Example - $ a-- donnera 9

6

->

L'opérateur de flèche est principalement utilisé pour déréférencer une méthode ou une variable d'un objet ou d'un nom de classe

Example - $ obj->$a is an example to access variable $a de l'objet $ obj.

Priorité des opérateurs Perl

Le tableau suivant répertorie tous les opérateurs de la priorité la plus élevée à la plus basse.

Afficher l'exemple

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

Ce chapitre vous donnera les notions de base sur la manière de traiter et de manipuler les dates et heures en Perl.

Date et heure actuelles

Commençons avec localtime(), qui renvoie les valeurs de la date et de l'heure actuelles si aucun argument n'est fourni. Voici la liste de 9 éléments renvoyée par lelocaltime fonction lors de l'utilisation dans un contexte de liste -

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

Essayez l'exemple suivant pour imprimer différents éléments renvoyés par la fonction 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";

Lorsque le code ci-dessus est exécuté, il produit le résultat suivant -

16 Feb Sat

Si vous utilisez la fonction localtime () dans un contexte scalaire, elle renverra la date et l'heure du fuseau horaire actuel défini dans le système. Essayez l'exemple suivant pour imprimer la date et l'heure actuelles au format complet -

#!/usr/local/bin/perl
 
$datestring = localtime();
print "Local date and time $datestring\n";

Lorsque le code ci-dessus est exécuté, il produit le résultat suivant -

Local date and time Sat Feb 16 06:50:45 2013

Heure GMT

La fonction gmtime()fonctionne comme la fonction localtime () mais les valeurs renvoyées sont localisées pour le fuseau horaire standard de Greenwich. Lorsqu'il est appelé dans un contexte de liste, $ isdst, la dernière valeur renvoyée par gmtime, est toujours 0. Il n'y a pas d'heure d'été en GMT.

Vous devriez noter le fait que localtime () renverra l'heure locale actuelle sur la machine qui exécute le script et gmtime () renverra l'heure universelle de Greenwich, ou GMT (ou UTC).

Essayez l'exemple suivant pour imprimer la date et l'heure actuelles mais à l'échelle GMT -

#!/usr/local/bin/perl

$datestring = gmtime(); print "GMT date and time $datestring\n";

Lorsque le code ci-dessus est exécuté, il produit le résultat suivant -

GMT date and time Sat Feb 16 13:50:45 2013

Format de la date et de l'heure

Vous pouvez utiliser la fonction localtime () pour obtenir une liste de 9 éléments et plus tard, vous pouvez utiliser le printf() fonction pour formater la date et l'heure en fonction de vos besoins comme suit -

#!/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);

Lorsque le code ci-dessus est exécuté, il produit le résultat suivant -

Time Format - HH:MM:SS
06:58:52

Heure de l'époque

Vous pouvez utiliser la fonction time () pour obtenir l'heure de l'époque, c'est-à-dire le nombre de secondes qui se sont écoulées depuis une date donnée, sous Unix est le 1er janvier 1970.

#!/usr/local/bin/perl
 
$epoc = time(); print "Number of seconds since Jan 1, 1970 - $epoc\n";

Lorsque le code ci-dessus est exécuté, il produit le résultat suivant -

Number of seconds since Jan 1, 1970 - 1361022130

Vous pouvez convertir un nombre donné de secondes en chaîne de date et d'heure comme suit -

#!/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";

Lorsque le code ci-dessus est exécuté, il produit le résultat suivant -

Current date and time Tue Jun  5 05:54:43 2018
Yesterday's date and time Mon Jun  4 05:54:43 2018

Fonction POSIX strftime ()

Vous pouvez utiliser la fonction POSIX strftime()pour formater la date et l'heure à l'aide du tableau suivant. Veuillez noter que les spécificateurs marqués d'un astérisque (*) dépendent des paramètres régionaux.

Prescripteur Remplacé par Exemple
%a Nom abrégé du jour de la semaine * Thu
%A Nom complet du jour de la semaine * Thursday
%b Nom du mois abrégé * Aug
%B Nom complet du mois * August
%c Représentation de la date et de l'heure * Thu Aug 23 14:55:02 2001
%C Année divisée par 100 et tronquée en entier ( 00-99) 20
%d Jour du mois, sans remplissage ( 01-31) 23
%D MM/DD/YYDate courte , équivalente à%m/%d/%y 08/23/01
%e Jour du mois, rembourré d'espace ( 1-31) 23
%F YYYY-MM-DDDate courte , équivalente à%Y-%m-%d 2001-08-23
%g Année basée sur la semaine, deux derniers chiffres ( 00-99) 01
%G Année basée sur la semaine 2001
%h Nom abrégé du mois * (identique à %b) Aug
%H Heure au format 24h ( 00-23) 14
%I Heure au format 12h ( 01-12) 02
%j Jour de l'année ( 001-366) 235
%m Mois sous forme de nombre décimal ( 01-12) 08
%M Minute ( 00-59) 55
%n Caractère de nouvelle ligne ( '\n')
%p Désignation AM ou PM PM
%r Horloge de 12 heures * 02:55:02 pm
%R 24 heures HH:MM, équivalent à%H:%M 14:55
%S Deuxième ( 00-61) 02
%t Caractère de tabulation horizontale ( '\t')
%T Format d'heure ISO 8601 ( HH:MM:SS), équivalent à%H:%M:%S 14:55
%u Jour de la semaine ISO 8601 comme nombre avec lundi comme 1( 1-7) 4
%U Numéro de la semaine avec le premier dimanche comme premier jour de la première semaine ( 00-53) 33
%V Numéro de semaine ISO 8601 ( 00-53) 34
%w Jour de la semaine sous forme de nombre décimal avec dimanche sous forme de 0( 0-6) 4
%W Numéro de la semaine avec le premier lundi comme premier jour de la première semaine ( 00-53) 34
%x Représentation de la date * 08/23/01
%X Représentation du temps * 14:55:02
%y Année, deux derniers chiffres ( 00-99) 01
%Y An 2001
%z

Décalage ISO 8601 par rapport à UTC dans le fuseau horaire (1 minute = 1, 1 heure = 100)

Si le fuseau horaire ne peut pas être défini, aucun caractère

+100
%Z

Nom ou abréviation du fuseau horaire *

Si le fuseau horaire ne peut pas être défini, aucun caractère

CDT
%% Un %signe %

Vérifions l'exemple suivant pour comprendre l'utilisation -

#!/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");

Lorsque le code ci-dessus est exécuté, il produit le résultat suivant -

date and time - Sat Feb 16 07:10:23 2013
date and time - Sat Feb 16 14:10:23 2013

Un sous-programme ou une fonction Perl est un groupe d'instructions qui exécutent ensemble une tâche. Vous pouvez diviser votre code en sous-programmes distincts. La façon dont vous divisez votre code entre différents sous-programmes dépend de vous, mais logiquement, la division est généralement de sorte que chaque fonction effectue une tâche spécifique.

Perl utilise les termes sous-programme, méthode et fonction de manière interchangeable.

Définir et appeler un sous-programme

La forme générale d'une définition de sous-programme dans le langage de programmation Perl est la suivante:

sub subroutine_name {
   body of the subroutine
}

La manière typique d'appeler ce sous-programme Perl est la suivante:

subroutine_name( list of arguments );

Dans les versions de Perl antérieures à 5.0, la syntaxe pour appeler les sous-programmes était légèrement différente, comme indiqué ci-dessous. Cela fonctionne toujours dans les dernières versions de Perl, mais ce n'est pas recommandé car il contourne les prototypes de sous-programmes.

&subroutine_name( list of arguments );

Jetons un œil à l'exemple suivant, qui définit une fonction simple, puis appelons-la. Parce que Perl compile votre programme avant de l'exécuter, peu importe où vous déclarez votre sous-programme.

#!/usr/bin/perl

# Function definition
sub Hello {
   print "Hello, World!\n";
}

# Function call
Hello();

Lorsque le programme ci-dessus est exécuté, il produit le résultat suivant -

Hello, World!

Passer des arguments à un sous-programme

Vous pouvez passer divers arguments à un sous-programme comme vous le faites dans n'importe quel autre langage de programmation et ils peuvent être accédés à l'intérieur de la fonction en utilisant le tableau spécial @_. Ainsi, le premier argument de la fonction est dans$_[0], the second is in $_ [1], et ainsi de suite.

Vous pouvez passer des tableaux et des hachages en tant qu'arguments comme n'importe quel scalaire, mais en passant plus d'un tableau ou hachage, ils perdent normalement leurs identités séparées. Nous utiliserons donc des références (expliquées dans le chapitre suivant) pour passer n'importe quel tableau ou hachage.

Essayons l'exemple suivant, qui prend une liste de nombres puis imprime leur moyenne -

#!/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);

Lorsque le programme ci-dessus est exécuté, il produit le résultat suivant -

Average for the given numbers : 20

Passer des listes aux sous-programmes

Comme la variable @_ est un tableau, elle peut être utilisée pour fournir des listes à un sous-programme. Cependant, en raison de la manière dont Perl accepte et analyse les listes et les tableaux, il peut être difficile d'extraire les éléments individuels de @_. Si vous devez passer une liste avec d'autres arguments scalaires, créez une liste comme dernier argument comme indiqué ci-dessous -

#!/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);

Lorsque le programme ci-dessus est exécuté, il produit le résultat suivant -

Given list is 10 1 2 3 4

Passer des hachages aux sous-programmes

Lorsque vous fournissez un hachage à un sous-programme ou à un opérateur qui accepte une liste, le hachage est automatiquement traduit en une liste de paires clé / valeur. Par exemple -

#!/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);

Lorsque le programme ci-dessus est exécuté, il produit le résultat suivant -

name : Tom
age : 19

Renvoyer la valeur d'un sous-programme

Vous pouvez renvoyer une valeur à partir d'un sous-programme comme vous le faites dans n'importe quel autre langage de programmation. Si vous ne renvoyez pas une valeur à partir d'un sous-programme, le dernier calcul effectué dans un sous-programme est également automatiquement la valeur de retour.

Vous pouvez renvoyer des tableaux et des hachages à partir du sous-programme comme n'importe quel scalaire, mais le renvoi de plusieurs tableaux ou hachages les fait normalement perdre leurs identités distinctes. Nous allons donc utiliser des références (expliquées dans le chapitre suivant) pour renvoyer n'importe quel tableau ou hachage d'une fonction.

Essayons l'exemple suivant, qui prend une liste de nombres puis renvoie leur moyenne -

#!/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";

Lorsque le programme ci-dessus est exécuté, il produit le résultat suivant -

Average for the given numbers : 20

Variables privées dans un sous-programme

Par défaut, toutes les variables en Perl sont des variables globales, ce qui signifie qu'elles sont accessibles de n'importe où dans le programme. Mais tu peux créerprivate variables appelées lexical variables à tout moment avec le my opérateur.

le myL'opérateur limite une variable à une région de code particulière dans laquelle elle peut être utilisée et accessible. En dehors de cette région, cette variable ne peut pas être utilisée ou accessible. Cette région s'appelle sa portée. Une portée lexicale est généralement un bloc de code entouré d'un ensemble d'accolades, telles que celles définissant le corps du sous-programme ou celles marquant les blocs de code des instructions if, while, for, foreach et eval .

Voici un exemple vous montrant comment définir une ou plusieurs variables privées à l'aide de my opérateur -

sub somefunc {
   my $variable; # $variable is invisible outside somefunc()
   my ($another, @an_array, %a_hash); # declaring many variables at once
}

Vérifions l'exemple suivant pour faire la distinction entre les variables globales et privées -

#!/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";

Lorsque le programme ci-dessus est exécuté, il produit le résultat suivant -

Inside the function Hello, Perl!
Outside the function Hello, World!

Valeurs temporaires via local ()

le localest principalement utilisé lorsque la valeur actuelle d'une variable doit être visible par les sous-programmes appelés. Un local donne juste des valeurs temporaires aux variables globales (c'est-à-dire package). C'est ce qu'on appelle la portée dynamique . La portée lexicale est effectuée avec my, qui fonctionne plus comme les déclarations automatiques de C.

Si plus d'une variable ou expression est donnée à local, elles doivent être placées entre parenthèses. Cet opérateur fonctionne en enregistrant les valeurs actuelles de ces variables dans sa liste d'arguments sur une pile cachée et en les restaurant à la sortie du bloc, du sous-programme ou de l'évaluation.

Vérifions l'exemple suivant pour faire la distinction entre les variables globales et locales -

#!/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";

Lorsque le programme ci-dessus est exécuté, il produit le résultat suivant -

Inside the function PrintMe Hello, Perl!
Inside the function PrintHello Hello, Perl!
Outside the function Hello, World!

Variables d'état via state ()

Il existe un autre type de variables lexicales, qui sont similaires aux variables privées mais qui conservent leur état et ne sont pas réinitialisées lors de plusieurs appels des sous-programmes. Ces variables sont définies à l'aide dustate opérateur et disponible à partir de Perl 5.9.4.

Vérifions l'exemple suivant pour démontrer l'utilisation de state variables -

#!/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();
}

Lorsque le programme ci-dessus est exécuté, il produit le résultat suivant -

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

Avant Perl 5.10, vous deviez l'écrire comme ceci -

#!/usr/bin/perl

{
   my $count = 0; # initial value

   sub PrintCount {
      print "Value of counter is $count\n"; $count++;
   }
}

for (1..5) {
   PrintCount();
}

Contexte d'appel de sous-programme

Le contexte d'un sous-programme ou d'une instruction est défini comme le type de valeur de retour attendu. Cela vous permet d'utiliser une seule fonction qui renvoie des valeurs différentes en fonction de ce que l'utilisateur attend de recevoir. Par exemple, le localtime () suivant renvoie une chaîne lorsqu'il est appelé dans un contexte scalaire, mais il renvoie une liste lorsqu'il est appelé dans un contexte de liste.

my $datestring = localtime( time );

Dans cet exemple, la valeur de $ timestr est désormais une chaîne composée de la date et de l'heure actuelles, par exemple, Thu Nov 30 15:21:33 2000. Inversement -

($sec,$min,$hour,$mday,$mon, $year,$wday,$yday,$isdst) = localtime(time);

Désormais, les variables individuelles contiennent les valeurs correspondantes renvoyées par le sous-programme localtime ().

Une référence Perl est un type de données scalaire qui contient l'emplacement d'une autre valeur qui peut être scalaire, des tableaux ou des hachages. En raison de sa nature scalaire, une référence peut être utilisée n'importe où, un scalaire peut être utilisé.

Vous pouvez créer des listes contenant des références à d'autres listes, qui peuvent contenir des références à des hachages, etc. C'est ainsi que les structures de données imbriquées sont construites en Perl.

Créer des références

Il est facile de créer une référence pour n'importe quelle variable, sous-programme ou valeur en la préfixant avec une barre oblique inverse comme suit -

$scalarref = \$foo; $arrayref  = \@ARGV;
$hashref = \%ENV; $coderef   = \&handler;
$globref   = \*foo;

Vous ne pouvez pas créer une référence sur un handle d'E / S (filehandle ou dirhandle) à l'aide de l'opérateur de barre oblique inverse, mais une référence à un tableau anonyme peut être créée à l'aide des crochets comme suit -

$arrayref = [1, 2, ['a', 'b', 'c']];

De la même manière, vous pouvez créer une référence à un hachage anonyme en utilisant les accolades comme suit -

$hashref = {
   'Adam'  => 'Eve',
   'Clyde' => 'Bonnie',
};

Une référence à un sous-programme anonyme peut être créée en utilisant sub sans sous-nom comme suit -

$coderef = sub { print "Boink!\n" };

Déréférencement

Le déréférencement renvoie la valeur d'un point de référence à l'emplacement. Pour déréférencer une référence, utilisez simplement $, @ ou% comme préfixe de la variable de référence selon que la référence pointe vers un scalaire, un tableau ou un hachage. Voici l'exemple pour expliquer le concept -

#!/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";

Lorsque le programme ci-dessus est exécuté, il produit le résultat suivant -

Value of 10 is : 10
Value of 1 2 3 is : 123
Value of %var is : key220key110

Si vous n'êtes pas sûr d'un type de variable, il est facile de connaître son type en utilisant ref, qui renvoie l'une des chaînes suivantes si son argument est une référence. Sinon, il renvoie faux -

SCALAR
ARRAY
HASH
CODE
GLOB
REF

Essayons l'exemple suivant -

#!/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";

Lorsque le programme ci-dessus est exécuté, il produit le résultat suivant -

Reference type in r : SCALAR
Reference type in r : ARRAY
Reference type in r : HASH

Références circulaires

Une référence circulaire se produit lorsque deux références contiennent une référence l'une à l'autre. Il faut être prudent lors de la création de références sinon une référence circulaire peut entraîner des fuites de mémoire. Voici un exemple -

#!/usr/bin/perl

 my $foo = 100;
 $foo = \$foo;
 
 print "Value of foo is : ", $$foo, "\n";

Lorsque le programme ci-dessus est exécuté, il produit le résultat suivant -

Value of foo is : REF(0x9aae38)

Références aux fonctions

Cela peut se produire si vous devez créer un gestionnaire de signaux afin de pouvoir produire une référence à une fonction en précédant ce nom de fonction avec \ & et pour déréférencer cette référence, il vous suffit de préfixer la variable de référence en utilisant une esperluette &. Voici un exemple -

#!/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);

Lorsque le programme ci-dessus est exécuté, il produit le résultat suivant -

Item : name
Item : Tom
Item : age
Item : 19

Perl utilise un modèle d'écriture appelé «format» pour produire des rapports. Pour utiliser la fonctionnalité de format de Perl, vous devez d'abord définir un format, puis vous pouvez utiliser ce format pour écrire des données formatées.

Définir un format

Voici la syntaxe pour définir un format Perl -

format FormatName =
fieldline
value_one, value_two, value_three
fieldline
value_one, value_two
.

Ici FormatNamereprésente le nom du format. lefieldlineest la manière spécifique, les données doivent être formatées. Les lignes de valeurs représentent les valeurs qui seront entrées dans la ligne de champ. Vous terminez le format avec une seule période.

Prochain fieldlinepeut contenir n'importe quel texte ou détenteurs de champ. Les détenteurs de champ contiennent de l'espace pour les données qui y seront placées à une date ultérieure. Un fieldholder a le format -

@<<<<

Ce champ est justifié à gauche, avec un espace de champ de 5. Vous devez compter le signe @ et les signes <pour connaître le nombre d'espaces dans le champ. Les autres détenteurs de champ comprennent -

@>>>> right-justified
@|||| centered
@####.## numeric field holder
@* multiline field holder

Un exemple de format serait -

format EMPLOYEE =
===================================
@<<<<<<<<<<<<<<<<<<<<<< @<< 
$name $age @#####.## $salary
===================================
.

Dans cet exemple, $ name sera écrit comme justifié à gauche dans les 22 espaces de caractères et après cet âge sera écrit dans deux espaces.

Utilisation du format

Afin d'appeler cette déclaration de format, nous utiliserions le write mot-clé -

write EMPLOYEE;

Le problème est que le nom du format est généralement le nom d'un descripteur de fichier ouvert et que l'instruction d'écriture enverra la sortie à ce descripteur de fichier. Comme nous voulons que les données soient envoyées au STDOUT, nous devons associer EMPLOYEE au descripteur de fichier STDOUT. Cependant, nous devons d'abord nous assurer que STDOUT est notre descripteur de fichier sélectionné, en utilisant la fonction select ().

select(STDOUT);

Nous associerions ensuite EMPLOYEE à STDOUT en définissant le nouveau nom de format avec STDOUT, en utilisant la variable spéciale $ ~ ou $ FORMAT_NAME comme suit -

$~ = "EMPLOYEE";

Quand nous faisons maintenant un write (), les données seraient envoyées à STDOUT. Souvenez-vous: si vous allez écrire votre rapport dans un autre descripteur de fichier au lieu de STDOUT, vous pouvez utiliser la fonction select () pour sélectionner ce descripteur de fichier et le reste de la logique restera le même.

Prenons l'exemple suivant. Ici, nous avons des valeurs codées en dur juste pour montrer l'utilisation. En utilisation réelle, vous lirez les valeurs d'un fichier ou d'une base de données pour générer des rapports réels et vous devrez peut-être réécrire le rapport final dans un fichier.

#!/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;
}

Une fois exécuté, cela produira le résultat suivant -

===================================
Ali                     20
  2000.00
===================================
===================================
Raza                    30
  2500.00
===================================
===================================
Jaffer                  40
  4000.00
===================================

Définir un en-tête de rapport

Tout va bien. Mais vous seriez intéressé à ajouter un en-tête à votre rapport. Cet en-tête sera imprimé en haut de chaque page. C'est très simple de le faire. En plus de définir un modèle, vous devrez définir un en-tête et l'affecter à la variable $ ^ ou $ 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;
}

Votre rapport ressemblera maintenant à -

===================================
Name                    Age
===================================
===================================
Ali                     20
  2000.00
===================================
===================================
Raza                    30
  2500.00
===================================
===================================
Jaffer                  40
  4000.00
===================================

Définir une pagination

Qu'en est-il si votre rapport prend plus d'une page? Vous avez une solution pour cela, utilisez simplement$% ou $ FORMAT_PAGE_NUMBER vairable avec en-tête comme suit -

format EMPLOYEE_TOP =
===================================
Name                    Age Page @<
                                 $%
===================================                               
.

Maintenant, votre sortie ressemblera à ceci -

===================================
Name                    Age Page 1
===================================
===================================
Ali                     20
  2000.00
===================================
===================================
Raza                    30
  2500.00
===================================
===================================
Jaffer                  40
  4000.00
===================================

Nombre de lignes sur une page

Vous pouvez définir le nombre de lignes par page à l'aide d'une variable spéciale $= (ou $ FORMAT_LINES_PER_PAGE), Par défaut, $ = sera 60.

Définir un pied de page de rapport

Alors que $ ^ ou $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 $- ou $ FORMAT_LINES_LEFT avant chaque write () et imprimez vous-même le pied de page si nécessaire en utilisant un autre format défini comme suit -

format EMPLOYEE_BOTTOM =
End of Page @<
            $%
.

Pour un ensemble complet de variables liées au formatage, veuillez vous référer à la section Variables spéciales Perl .

Les bases de la gestion des fichiers sont simples: vous associez un filehandle avec une entité externe (généralement un fichier), puis utilisez une variété d'opérateurs et de fonctions dans Perl pour lire et mettre à jour les données stockées dans le flux de données associé au descripteur de fichier.

Un descripteur de fichier est une structure Perl interne nommée qui associe un fichier physique à un nom. Tous les descripteurs de fichiers sont capables d'un accès en lecture / écriture, vous pouvez donc lire et mettre à jour tout fichier ou périphérique associé à un descripteur de fichier. Cependant, lorsque vous associez un descripteur de fichier, vous pouvez spécifier le mode dans lequel le descripteur de fichier est ouvert.

Trois descripteurs de fichiers de base sont - STDIN, STDOUT, et STDERR, qui représentent respectivement les périphériques d'entrée standard, de sortie standard et d'erreur standard.

Ouverture et fermeture de fichiers

Il existe deux fonctions suivantes avec plusieurs formulaires, qui peuvent être utilisées pour ouvrir n'importe quel fichier nouveau ou existant en Perl.

open FILEHANDLE, EXPR
open FILEHANDLE

sysopen FILEHANDLE, FILENAME, MODE, PERMS
sysopen FILEHANDLE, FILENAME, MODE

Ici FILEHANDLE est le descripteur de fichier renvoyé par le open function et EXPR est l'expression ayant le nom de fichier et le mode d'ouverture du fichier.

Fonction ouverte

Voici la syntaxe pour ouvrir file.txten mode lecture seule. Ici, moins de <signe indique que le fichier doit être ouvert en mode lecture seule.

open(DATA, "<file.txt");

Ici, DATA est le descripteur de fichier, qui sera utilisé pour lire le fichier. Voici l'exemple, qui ouvrira un fichier et imprimera son contenu sur l'écran.

#!/usr/bin/perl

open(DATA, "<file.txt") or die "Couldn't open file file.txt, $!"; while(<DATA>) { print "$_";
}

Voici la syntaxe pour ouvrir file.txt en mode écriture. Ici, le signe inférieur à> indique que le fichier doit être ouvert en mode d'écriture.

open(DATA, ">file.txt") or die "Couldn't open file file.txt, $!";

Cet exemple tronque (vide) le fichier avant de l'ouvrir pour l'écriture, ce qui peut ne pas être l'effet souhaité. Si vous souhaitez ouvrir un fichier en lecture et en écriture, vous pouvez mettre un signe plus avant les caractères> ou <.

Par exemple, pour ouvrir un fichier à mettre à jour sans le tronquer -

open(DATA, "+<file.txt"); or die "Couldn't open file file.txt, $!";

Pour tronquer d'abord le fichier -

open DATA, "+>file.txt" or die "Couldn't open file file.txt, $!";

Vous pouvez ouvrir un fichier en mode ajout. Dans ce mode, le point d'écriture sera défini à la fin du fichier.

open(DATA,">>file.txt") || die "Couldn't open file file.txt, $!";

Un double >> ouvre le fichier à ajouter, en plaçant le pointeur de fichier à la fin, de sorte que vous puissiez immédiatement commencer à ajouter des informations. Cependant, vous ne pouvez pas le lire sauf si vous placez également un signe plus devant lui -

open(DATA,"+>>file.txt") || die "Couldn't open file file.txt, $!";

Voici le tableau, qui donne les valeurs possibles des différents modes

Sr.No. Entités et définition
1

< or r

Accès en lecture seule

2

> or w

Crée, écrit et tronque

3

>> or a

Écrit, ajoute et crée

4

+< or r+

Lit et écrit

5

+> or w+

Lit, écrit, crée et tronque

6

+>> or a+

Lit, écrit, ajoute et crée

Fonction Sysopen

le sysopen La fonction est similaire à la fonction ouverte principale, sauf qu'elle utilise le système open() fonction, en utilisant les paramètres qui lui sont fournis comme paramètres de la fonction système -

Par exemple, pour ouvrir un fichier à mettre à jour, émuler le +<filename format depuis ouvert -

sysopen(DATA, "file.txt", O_RDWR);

Ou pour tronquer le fichier avant la mise à jour -

sysopen(DATA, "file.txt", O_RDWR|O_TRUNC );

Vous pouvez utiliser O_CREAT pour créer un nouveau fichier et O_WRONLY - pour ouvrir le fichier en mode écriture seule et O_RDONLY - pour ouvrir le fichier en mode lecture seule.

le PERMSL'argument spécifie les autorisations de fichier pour le fichier spécifié, s'il doit être créé. Par défaut, il faut0x666.

Voici le tableau, qui donne les valeurs possibles de MODE.

Sr.No. Entités et définition
1

O_RDWR

Lire et écrire

2

O_RDONLY

Lecture seulement

3

O_WRONLY

Écriture seulement

4

O_CREAT

Créer le fichier

5

O_APPEND

Ajouter le fichier

6

O_TRUNC

Tronquer le fichier

sept

O_EXCL

S'arrête si le fichier existe déjà

8

O_NONBLOCK

Utilisation non bloquante

Fermer la fonction

Pour fermer un descripteur de fichier, et donc dissocier le descripteur de fichier du fichier correspondant, vous utilisez le closefonction. Cela vide les tampons du descripteur de fichier et ferme le descripteur de fichier du système.

close FILEHANDLE
close

Si aucun FILEHANDLE n'est spécifié, il ferme le descripteur de fichier actuellement sélectionné. Il renvoie true uniquement s'il parvient à vider les tampons et à fermer le fichier.

close(DATA) || die "Couldn't close file properly";

Lecture et écriture de fichiers

Une fois que vous avez un descripteur de fichier ouvert, vous devez être capable de lire et d'écrire des informations. Il existe différentes manières de lire et d'écrire des données dans le fichier.

L'opérateur <FILEHANDL>

La principale méthode de lecture des informations à partir d'un descripteur de fichier ouvert est l'opérateur <FILEHANDLE>. Dans un contexte scalaire, il renvoie une seule ligne du descripteur de fichier. Par exemple -

#!/usr/bin/perl

print "What is your name?\n";
$name = <STDIN>;
print "Hello $name\n";

Lorsque vous utilisez l'opérateur <FILEHANDLE> dans un contexte de liste, il renvoie une liste de lignes à partir du descripteur de fichier spécifié. Par exemple, pour importer toutes les lignes d'un fichier dans un tableau -

#!/usr/bin/perl

open(DATA,"<import.txt") or die "Can't open data";
@lines = <DATA>;
close(DATA);

Fonction getc

La fonction getc renvoie un seul caractère du FILEHANDLE spécifié, ou STDIN si aucun n'est spécifié -

getc FILEHANDLE
getc

S'il y a eu une erreur ou si le descripteur de fichier est à la fin du fichier, undef est renvoyé à la place.

fonction de lecture

La fonction de lecture lit un bloc d'informations à partir du descripteur de fichier mis en mémoire tampon: Cette fonction est utilisée pour lire les données binaires du fichier.

read FILEHANDLE, SCALAR, LENGTH, OFFSET
read FILEHANDLE, SCALAR, LENGTH

La longueur des données lues est définie par LENGTH et les données sont placées au début de SCALAR si aucun OFFSET n'est spécifié. Sinon, les données sont placées après les octets OFFSET dans SCALAR. La fonction renvoie le nombre d'octets lus en cas de succès, zéro à la fin du fichier ou undef s'il y a eu une erreur.

Fonction d'impression

Pour toutes les différentes méthodes utilisées pour lire les informations à partir des descripteurs de fichiers, la fonction principale de réécriture des informations est la fonction d'impression.

print FILEHANDLE LIST
print LIST
print

La fonction d'impression imprime la valeur évaluée de LIST dans FILEHANDLE ou dans le descripteur de fichier de sortie actuel (STDOUT par défaut). Par exemple -

print "Hello World!\n";

Copie de fichiers

Voici l'exemple, qui ouvre un fichier existant file1.txt et le lit ligne par ligne et génère une autre copie de fichier file2.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 );

Renommer un fichier

Voici un exemple qui montre comment renommer un fichier file1.txt en file2.txt. En supposant que le fichier soit disponible dans le répertoire / usr / test.

#!/usr/bin/perl

rename ("/usr/test/file1.txt", "/usr/test/file2.txt" );

Cette fonction renames prend deux arguments et renomme simplement le fichier existant.

Supprimer un fichier existant

Voici un exemple qui montre comment supprimer un fichier file1.txt à l'aide du unlink fonction.

#!/usr/bin/perl

unlink ("/usr/test/file1.txt");

Positionnement dans un fichier

Vous pouvez utiliser pour tell fonction pour connaître la position actuelle d'un fichier et seek pour pointer une position particulière dans le fichier.

dire Fonction

La première condition est de trouver votre position dans un fichier, ce que vous faites en utilisant la fonction tell -

tell FILEHANDLE
tell

Cela renvoie la position du pointeur de fichier, en octets, dans FILEHANDLE si spécifié, ou le descripteur de fichier sélectionné par défaut actuel si aucun n'est spécifié.

Fonction de recherche

La fonction de recherche positionne le pointeur de fichier sur le nombre d'octets spécifié dans un fichier -

seek FILEHANDLE, POSITION, WHENCE

La fonction utilise la fonction système fseek et vous avez la même capacité à vous positionner par rapport à trois points différents: le début, la fin et la position actuelle. Pour ce faire, spécifiez une valeur pour WHENCE.

Zéro définit le positionnement par rapport au début du fichier. Par exemple, la ligne définit le pointeur de fichier sur le 256e octet du fichier.

seek DATA, 256, 0;

Informations sur le fichier

Vous pouvez tester certaines fonctionnalités très rapidement dans Perl en utilisant une série d'opérateurs de test connus collectivement sous le nom de tests -X. Par exemple, pour effectuer un test rapide des différentes autorisations sur un fichier, vous pouvez utiliser un script comme celui-ci -

#/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";
}

Voici la liste des fonctionnalités que vous pouvez rechercher pour un fichier ou un répertoire -

Sr.No. Opérateur et définition
1

-A

Heure de début du script moins heure du dernier accès au fichier, en jours.

2

-B

Est-ce un fichier binaire?

3

-C

Heure de début du script moins l'heure du dernier changement d'inode du fichier, en jours.

3

-M

Heure de début du script moins l'heure de modification du fichier, en jours.

4

-O

Le fichier appartient-il au véritable ID utilisateur?

5

-R

Le fichier est-il lisible par l'ID utilisateur réel ou le groupe réel?

6

-S

Le fichier est-il une socket?

sept

-T

Est-ce un fichier texte?

8

-W

Le fichier est-il accessible en écriture avec l'ID utilisateur réel ou le groupe réel?

9

-X

Le fichier est-il exécutable par l'ID utilisateur réel ou le groupe réel?

dix

-b

S'agit-il d'un fichier spécial de bloc?

11

-c

S'agit-il d'un fichier spécial de caractère?

12

-d

Le fichier est-il un répertoire?

13

-e

Le fichier existe-t-il?

14

-f

Est-ce un fichier simple?

15

-g

Le fichier a-t-il le bit setgid défini?

16

-k

Le fichier a-t-il le bit collant défini?

17

-l

Le fichier est-il un lien symbolique?

18

-o

Le fichier appartient-il à l'ID utilisateur effectif?

19

-p

Le fichier est-il un tube nommé?

20

-r

Le fichier est-il lisible par l'utilisateur effectif ou l'ID de groupe?

21

-s

Renvoie la taille du fichier, taille zéro = fichier vide.

22

-t

Le descripteur de fichier est-il ouvert par un TTY (terminal)?

23

-u

Le fichier a-t-il le bit setuid défini?

24

-w

Le fichier est-il accessible en écriture par l'utilisateur effectif ou l'ID de groupe?

25

-x

Le fichier est-il exécutable par l'utilisateur effectif ou l'ID de groupe?

26

-z

La taille du fichier est-elle nulle?

Voici les fonctions standard utilisées pour jouer avec les répertoires.

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.

Afficher tous les fichiers

Il existe différentes manières de lister tous les fichiers disponibles dans un répertoire particulier. Commençons par utiliser le moyen simple d'obtenir et de lister tous les fichiers en utilisant leglob opérateur -

#!/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";
}

Voici un autre exemple, qui ouvre un répertoire et liste tous les fichiers disponibles dans ce répertoire.

#!/usr/bin/perl

opendir (DIR, '.') or die "Couldn't open directory, $!"; while ($file = readdir DIR) {
   print "$file\n";
}
closedir DIR;

Un autre exemple pour imprimer la liste des fichiers source C que vous pourriez utiliser est -

#!/usr/bin/perl

opendir(DIR, '.') or die "Couldn't open directory, $!";
foreach (sort grep(/^.*\.c$/,readdir(DIR))) { print "$_\n";
}
closedir DIR;

Créer un nouveau répertoire

Vous pouvez utiliser mkdirfonction pour créer un nouveau répertoire. Vous devrez disposer de l'autorisation requise pour créer un répertoire.

#!/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";

Supprimer un répertoire

Vous pouvez utiliser rmdirfonction pour supprimer un répertoire. Vous devrez disposer de l'autorisation requise pour supprimer un répertoire. De plus, ce répertoire doit être vide avant d'essayer de le supprimer.

#!/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";

Changer un répertoire

Vous pouvez utiliser chdirpour changer de répertoire et accéder à un nouvel emplacement. Vous aurez besoin de l'autorisation requise pour modifier un répertoire et accéder au nouveau répertoire.

#!/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";

L'exécution et les erreurs vont toujours de pair. Si vous ouvrez un fichier qui n'existe pas. alors si vous n'avez pas géré cette situation correctement, votre programme est considéré comme de mauvaise qualité.

Le programme s'arrête si une erreur se produit. Ainsi, une gestion correcte des erreurs est utilisée pour gérer divers types d'erreurs, qui peuvent survenir pendant l'exécution d'un programme et prendre les mesures appropriées au lieu d'arrêter complètement le programme.

Vous pouvez identifier et intercepter une erreur de différentes manières. Il est très facile de piéger les erreurs en Perl et de les gérer correctement. Voici quelques méthodes qui peuvent être utilisées.

L'instruction if

le if statementest le choix évident lorsque vous devez vérifier la valeur de retour d'une instruction; par exemple -

if(open(DATA, $file)) {
   ...
} else {
   die "Error: Couldn't open the file - $!";
}

Ici la variable $! renvoie le message d'erreur réel. Alternativement, nous pouvons réduire l'énoncé à une ligne dans les situations où cela a du sens de le faire; par exemple -

open(DATA, $file) || die "Error: Couldn't open the file $!";

La fonction sauf

le unlessfunction est l'opposé logique de if: les instructions peuvent contourner complètement l'état de réussite et être exécutées uniquement si l'expression renvoie false. Par exemple -

unless(chdir("/etc")) {
   die "Error: Can't change directory - $!";
}

le unlessL'instruction est mieux utilisée lorsque vous souhaitez déclencher une erreur ou une alternative uniquement si l'expression échoue. L'instruction a également du sens lorsqu'elle est utilisée dans une instruction sur une seule ligne -

die "Error: Can't change directory!: $!" unless(chdir("/etc"));

Ici, nous ne mourons que si l'opération chdir échoue et qu'elle se lit bien.

L'opérateur ternaire

Pour des tests très courts, vous pouvez utiliser l'opérateur conditionnel ?:

print(exists($hash{value}) ? 'There' : 'Missing',"\n");

Ce que nous essayons de réaliser n'est pas aussi clair ici, mais l'effet est le même que l'utilisation d'un if ou unlessdéclaration. L'opérateur conditionnel est mieux utilisé lorsque vous souhaitez renvoyer rapidement l'une des deux valeurs d'une expression ou d'une instruction.

La fonction d'avertissement

La fonction d'avertissement déclenche simplement un avertissement, un message est affiché sur STDERR, mais aucune autre action n'est entreprise. Il est donc plus utile si vous souhaitez simplement imprimer un avertissement pour l'utilisateur et poursuivre le reste de l'opération -

chdir('/etc') or warn "Can't change directory";

La fonction die

La fonction die fonctionne exactement comme warn, sauf qu'elle appelle aussi exit. Dans un script normal, cette fonction a pour effet de terminer immédiatement l'exécution. Vous devez utiliser cette fonction au cas où il serait inutile de continuer s'il y a une erreur dans le programme -

chdir('/etc') or die "Can't change directory";

Erreurs dans les modules

Il y a deux situations différentes que nous devrions être capables de gérer -

  • Signaler une erreur dans un module qui cite le nom de fichier et le numéro de ligne du module - ceci est utile lors du débogage d'un module, ou lorsque vous souhaitez spécifiquement déclencher une erreur liée au module plutôt que liée au script.

  • Signaler une erreur dans un module qui cite les informations de l'appelant afin que vous puissiez déboguer la ligne dans le script qui a provoqué l'erreur. Les erreurs générées de cette manière sont utiles à l'utilisateur final, car elles mettent en évidence l'erreur par rapport à la ligne d'origine du script appelant.

le warn et dieLes fonctions fonctionnent légèrement différemment de ce à quoi vous vous attendez lorsqu'elles sont appelées depuis un module. Par exemple, le module simple -

package T;

require Exporter;
@ISA = qw/Exporter/;
@EXPORT = qw/function/;
use Carp;

sub function {
   warn "Error in module!";
}
1;

Lorsqu'il est appelé à partir d'un script comme ci-dessous -

use T;
function();

Cela produira le résultat suivant -

Error in module! at T.pm line 9.

C'est plus ou moins ce à quoi vous pourriez vous attendre, mais pas nécessairement ce que vous voulez. Du point de vue d'un programmeur de module, les informations sont utiles car elles permettent de pointer vers un bogue dans le module lui-même. Pour un utilisateur final, les informations fournies sont assez inutiles, et pour tout le monde sauf le programmeur aguerri, c'est totalement inutile.

La solution à ces problèmes est le module Carp, qui fournit une méthode simplifiée pour signaler les erreurs dans les modules qui renvoient des informations sur le script appelant. Le module Carp fournit quatre fonctions: carpe, gloussement, croassement et aveux. Ces fonctions sont décrites ci-dessous.

La fonction carpe

La fonction carp est l'équivalent de base de warn et imprime le message dans STDERR sans réellement quitter le script et imprimer le nom du script.

package T;

require Exporter;
@ISA = qw/Exporter/;
@EXPORT = qw/function/;
use Carp;

sub function {
   carp "Error in module!";
}
1;

Lorsqu'il est appelé à partir d'un script comme ci-dessous -

use T;
function();

Cela produira le résultat suivant -

Error in module! at test.pl line 4

La fonction cluck

La fonction cluck est une sorte de carpe suralimentée, elle suit le même principe de base mais imprime également une trace de pile de tous les modules qui ont conduit à l'appel de la fonction, y compris les informations sur le script d'origine.

package T;

require Exporter;
@ISA = qw/Exporter/;
@EXPORT = qw/function/;
use Carp qw(cluck);

sub function {
   cluck "Error in module!";
}
1;

Lorsqu'il est appelé à partir d'un script comme ci-dessous -

use T;
function();

Cela produira le résultat suivant -

Error in module! at T.pm line 9
   T::function() called at test.pl line 4

La fonction croak

le croak fonction équivaut à die, sauf qu'il signale à l'appelant un niveau supérieur. Comme die, cette fonction quitte également le script après avoir signalé l'erreur à STDERR -

package T;

require Exporter;
@ISA = qw/Exporter/;
@EXPORT = qw/function/;
use Carp;

sub function {
   croak "Error in module!";
}
1;

Lorsqu'il est appelé à partir d'un script comme ci-dessous -

use T;
function();

Cela produira le résultat suivant -

Error in module! at test.pl line 4

Comme pour la carpe, les mêmes règles de base s'appliquent en ce qui concerne l'inclusion des informations de ligne et de fichier selon les fonctions d'avertissement et de dé.

La fonction confesser

le confess la fonction est comme cluck; il appelle die puis imprime une trace de pile jusqu'au script d'origine.

package T;

require Exporter;
@ISA = qw/Exporter/;
@EXPORT = qw/function/;
use Carp;

sub function {
   confess "Error in module!";
}
1;

Lorsqu'il est appelé à partir d'un script comme ci-dessous -

use T;
function();

Cela produira le résultat suivant -

Error in module! at T.pm line 9
   T::function() called at test.pl line 4

Certaines variables ont une signification prédéfinie et spéciale en Perl. Ce sont les variables qui utilisent des caractères de ponctuation après l'indicateur de variable habituel ($, @ ou%), comme $ _ (expliqué ci-dessous).

La plupart des variables spéciales ont un nom long en anglais, par exemple, la variable d'erreur du système d'exploitation $! peut être écrit comme $ OS_ERROR. Mais si vous allez utiliser des noms comme l'anglais, vous devrez mettre une ligneuse English;en haut de votre fichier programme. Cela guide l'interpréteur pour saisir la signification exacte de la variable.

La variable spéciale la plus couramment utilisée est $ _, qui contient l'entrée par défaut et la chaîne de recherche de modèle. Par exemple, dans les lignes suivantes -

#!/usr/bin/perl

foreach ('hickory','dickory','doc') {
   print $_;
   print "\n";
}

Une fois exécuté, cela produira le résultat suivant -

hickory
dickory
doc

Encore une fois, vérifions le même exemple sans utiliser la variable $ _ explicitement -

#!/usr/bin/perl

foreach ('hickory','dickory','doc') {
   print;
   print "\n";
}

Une fois exécuté, cela produira également le résultat suivant -

hickory
dickory
doc

La première fois que la boucle est exécutée, "hickory" est imprimé. La deuxième fois, "dickory" est imprimé, et la troisième fois, "doc" est imprimé. En effet, à chaque itération de la boucle, la chaîne actuelle est placée dans$_, and is used by default by print. Here are the places where Perl will assume $_ même si vous ne le spécifiez pas -

  • Diverses fonctions unaires, y compris des fonctions comme ord et int, ainsi que tous les tests de fichiers (-f, -d) à l'exception de -t, qui par défaut est STDIN.

  • Diverses fonctions de liste comme imprimer et dissocier.

  • Les opérations de correspondance de modèle m //, s /// et tr /// lorsqu'elles sont utilisées sans opérateur = ~.

  • La variable d'itérateur par défaut dans une boucle foreach si aucune autre variable n'est fournie.

  • La variable itératrice implicite dans les fonctions grep et map.

  • L'endroit par défaut pour placer un enregistrement d'entrée lorsque le résultat d'une opération d'entrée de ligne est testé par lui-même comme seul critère d'un test while (c'est-à-dire). Notez qu'en dehors d'un test while, cela ne se produira pas.

Types de variables spéciales

En fonction de l'utilisation et de la nature des variables spéciales, nous pouvons les classer dans les catégories suivantes -

  • Variables spéciales scalaires globales.
  • Variables spéciales de Global Array.
  • Variables spéciales de hachage global.
  • Gestionnaires de fichiers spéciaux globaux.
  • Constantes spéciales mondiales.
  • Variables spéciales d'expression régulière.
  • Variables spéciales Filehandle.

Variables spéciales scalaires globales

Voici la liste de toutes les variables spéciales scalaires. Nous avons répertorié les noms anglais correspondants ainsi que les noms symboliques.

$ _ L'espace d'entrée et de recherche de modèle par défaut.
$ ARG
$. Numéro de ligne d'entrée actuel du dernier descripteur de fichier lu. Une fermeture explicite sur le descripteur de fichier réinitialise le numéro de ligne.
$ NR
$ / Le séparateur d'enregistrement d'entrée; newline par défaut. S'il est défini sur la chaîne nulle, il traite les lignes vides comme des délimiteurs.
$ RS
$, Le séparateur de champ de sortie pour l'opérateur d'impression.
$ OFS
$ \ Le séparateur d'enregistrement de sortie pour l'opérateur d'impression.
$ ORS
$ " Comme "$", sauf qu'il s'applique aux valeurs de liste interpolées dans une chaîne entre guillemets (ou chaîne interprétée similaire). La valeur par défaut est un espace.
$ LIST_SEPARATOR
$; Le séparateur d'indice pour l'émulation de tableau multidimensionnel. La valeur par défaut est "\ 034".
$ SUBSCRIPT_SEPARATOR
$ ^ L Quel format produit pour effectuer un saut de formulaire. La valeur par défaut est "\ f".
$ FORMAT_FORMFEED
$: Jeu de caractères actuel après lequel une chaîne peut être interrompue pour remplir les champs de continuation (commençant par ^) dans un format. La valeur par défaut est "\ n" ".
$ FORMAT_LINE_BREAK_CHARACTERS
$ ^ A La valeur actuelle de l'accumulateur d'écriture pour les lignes de format.
$ ACCUMULATEUR
$ # Contient le format de sortie des nombres imprimés (obsolète).
$ OFMT
$? L'état renvoyé par la dernière fermeture de tube, la commande backtick (``) ou l'opérateur système.
$ CHILD_ERROR
$! S'il est utilisé dans un contexte numérique, renvoie la valeur actuelle de la variable errno, identifiant la dernière erreur d'appel système. S'il est utilisé dans un contexte de chaîne, renvoie la chaîne d'erreur système correspondante.
$OS_ERROR or $ERRNO
$ @ Le message d'erreur de syntaxe Perl de la dernière commande eval.
$ EVAL_ERROR
$$ Le pid du processus Perl exécutant ce script.
$ PROCESS_ID ou $ PID
$ < L'ID utilisateur réel (uid) de ce processus.
$REAL_USER_ID or $UID
$> L'ID utilisateur effectif de ce processus.
$ EFFECTIVE_USER_ID ou $ EUID
$ ( L'ID de groupe réel (gid) de ce processus.
$REAL_GROUP_ID or $GID
$) Le gid efficace de ce processus.
$ EFFECTIVE_GROUP_ID ou $ EGID
0 $ Contient le nom du fichier contenant le script Perl en cours d'exécution.
$ PROGRAM_NAME
$ [ L'index du premier élément d'un tableau et du premier caractère d'une sous-chaîne. La valeur par défaut est 0.
$] Renvoie la version plus le niveau de patch divisé par 1000.
$ PERL_VERSION
$ ^ D La valeur actuelle des indicateurs de débogage.
$ DÉBOGAGE
$ ^ E Message d'erreur étendu sur certaines plates-formes.
$ EXTENDED_OS_ERROR
$ ^ F Le descripteur de fichier système maximal, généralement 2.
$ SYSTEM_FD_MAX
$ ^ H Contient des conseils internes du compilateur activés par certains modules pragmatiques.
$ ^ Je La valeur actuelle de l'extension de modification sur place. Utilisez undef pour désactiver la modification sur place.
$ INPLACE_EDIT
^ M $ Le contenu de $M can be used as an emergency memory pool in case Perl dies with an out-of-memory error. Use of $M nécessite une compilation spéciale de Perl. Consultez le document INSTALL pour plus d'informations.
$ ^ O Contient le nom du système d'exploitation pour lequel le binaire Perl actuel a été compilé.
$ OSNAME
$ ^ P L'indicateur interne que le débogueur efface afin qu'il ne se débogue pas.
$ PERLDB
$ ^ T Heure à laquelle le script a commencé à s'exécuter, en secondes depuis l'époque.
$ BASETIME
$ ^ W La valeur actuelle du commutateur d'avertissement, true ou false.
$ AVERTISSEMENT
$ ^ X Le nom sous lequel le binaire Perl lui-même a été exécuté.
$ EXECUTABLE_NAME
$ ARGV Contient le nom du fichier actuel lors de la lecture depuis <ARGV>.

Variables spéciales de la matrice globale

@ARGV Le tableau contenant les arguments de ligne de commande destinés au script.
@INC Le tableau contenant la liste des emplacements où rechercher les scripts Perl à évaluer par les constructions do, require ou use.
@F Le tableau dans lequel les lignes d'entrée sont divisées lorsque le commutateur de ligne de commande -a est donné.

Variables spéciales de hachage global

% INC Le hachage contenant les entrées pour le nom de fichier de chaque fichier qui a été inclus via do ou require.
% ENV Le hachage contenant votre environnement actuel.
% SIG Le hachage utilisé pour définir les gestionnaires de signaux pour divers signaux.

Gestionnaires de fichiers spéciaux globaux

ARGV Le descripteur de fichier spécial qui itère sur les noms de fichiers de ligne de commande dans @ARGV. Habituellement écrit comme le descripteur de fichier nul dans <>.
STDERR Le descripteur de fichier spécial pour l'erreur standard dans n'importe quel package.
STDIN Le descripteur de fichier spécial pour l'entrée standard dans n'importe quel package.
STDOUT Le descripteur de fichier spécial pour la sortie standard dans n'importe quel package.
LES DONNÉES Le descripteur de fichier spécial qui fait référence à tout ce qui suit le jeton __END__ dans le fichier contenant le script. Ou, le descripteur de fichier spécial pour tout ce qui suit le jeton __DATA__ dans un fichier requis, tant que vous lisez des données dans le même package que __DATA__ a été trouvé.
_ (souligner) Le descripteur de fichier spécial utilisé pour mettre en cache les informations du dernier opérateur de test statistique, lstat ou de fichier.

Constantes spéciales mondiales

__FIN__ Indique la fin logique de votre programme. Tout texte suivant est ignoré, mais peut être lu via le descripteur de fichier DATA.
__FICHIER__ Représente le nom de fichier à l'endroit de votre programme où il est utilisé. Non interpolé en chaînes.
__LIGNE__ Représente le numéro de ligne actuel. Non interpolé en chaînes.
__PAQUET__ Représente le nom du package en cours au moment de la compilation, ou non défini s'il n'y a pas de package en cours. Non interpolé en chaînes.

Variables spéciales d'expression régulière

$ chiffre Contient le texte correspondant au jeu de parenthèses correspondant dans le dernier motif correspondant. Par exemple, $ 1 correspond à tout ce qui était contenu dans le premier jeu de parenthèses dans l'expression régulière précédente.
$ & La chaîne correspondant à la dernière correspondance de modèle réussie.
$ MATCH
$ ` La chaîne précédant tout ce qui correspond à la dernière correspondance de modèle réussie.
$ PREMATCH
$ ' La chaîne qui suit tout ce qui correspond à la dernière correspondance de modèle réussie.
$ POSTMATCH
$ + Dernière parenthèse correspondant au dernier modèle de recherche. Ceci est utile si vous ne savez pas lequel d'un ensemble de modèles alternatifs correspond. Par exemple: / Version: (. *) | Révision: (. *) / && ($rev = $+);
$ LAST_PAREN_MATCH

Variables spéciales Filehandle

$ | Si la valeur est différente de zéro, force un fflush (3) après chaque écriture ou impression sur le canal de sortie actuellement sélectionné.
$ OUTPUT_AUTOFLUSH
$% Le numéro de la page actuelle du canal de sortie actuellement sélectionné.
$ FORMAT_PAGE_NUMBER
$ = La longueur de page actuelle (lignes imprimables) du canal de sortie actuellement sélectionné. La valeur par défaut est 60.
$ FORMAT_LINES_PER_PAGE
$ - Le nombre de lignes restantes sur la page du canal de sortie actuellement sélectionné.
$ FORMAT_LINES_LEFT
$ ~ Le nom du format de rapport actuel pour le canal de sortie actuellement sélectionné. La valeur par défaut est le nom du descripteur de fichier.
$ FORMAT_NAME
$ ^ Le nom du format de haut de page actuel pour le canal de sortie actuellement sélectionné. La valeur par défaut est le nom du descripteur de fichier avec _TOP ajouté.
$ FORMAT_TOP_NAME

Chaque programmeur aura, bien sûr, ses propres préférences en ce qui concerne le formatage, mais il existe des directives générales qui faciliteront la lecture, la compréhension et la maintenance de vos programmes.

Le plus important est d'exécuter vos programmes sous l'option -w à tout moment. Vous pouvez le désactiver explicitement pour des portions de code particulières via le pragma no warnings ou la variable $ ^ W si vous le devez. Vous devez également toujours exécuter sous use strict ou en connaître la raison. L'utilisation de sigtrap et même l'utilisation de pragmas de diagnostic peuvent également s'avérer utiles.

En ce qui concerne l'esthétique de la disposition du code, la seule chose à laquelle Larry se soucie fortement est que l'accolade fermante d'un BLOC multiligne doit s'aligner avec le mot-clé qui a commencé la construction. Au-delà de cela, il a d'autres préférences qui ne sont pas si fortes -

  • Retrait de 4 colonnes.
  • Ouverture bouclée sur la même ligne que le mot-clé, si possible, sinon aligner.
  • Espace avant l'ouverture bouclée d'un BLOC multiligne.
  • Le BLOC d'une ligne peut être placé sur une seule ligne, y compris les boucles.
  • Pas d'espace avant le point-virgule.
  • Point-virgule omis dans BLOC "court" d'une ligne.
  • Espace autour de la plupart des opérateurs.
  • Espace autour d'un indice "complexe" (entre crochets).
  • Lignes vides entre les morceaux qui font des choses différentes.
  • Elles sans câlins.
  • Aucun espace entre le nom de la fonction et sa parenthèse ouvrante.
  • Espace après chaque virgule.
  • Longues lignes interrompues après un opérateur (sauf et et ou).
  • Espace après la dernière parenthèse correspondant à la ligne courante.
  • Alignez les éléments correspondants verticalement.
  • Omettez la ponctuation redondante tant que la clarté ne souffre pas.

Voici quelques autres problèmes de style plus importants auxquels il faut réfléchir: Ce n'est pas parce que vous POUVEZ faire quelque chose d'une manière particulière que vous DEVRIEZ le faire de cette façon. Perl est conçu pour vous donner plusieurs façons de faire n'importe quoi, alors pensez à choisir la plus lisible. Par exemple -

open(FOO,$foo) || die "Can't open $foo: $!";

Est mieux que -

die "Can't open $foo: $!" unless open(FOO,$foo);

Parce que la deuxième façon masque le point principal de l'instruction dans un modificateur. D'autre part,

print "Starting analysis\n" if $verbose;

Est mieux que -

$verbose && print "Starting analysis\n";

Parce que le point principal n'est pas de savoir si l'utilisateur a tapé -v ou non.

Ne passez pas par des contorsions stupides pour quitter une boucle en haut ou en bas, lorsque Perl fournit le dernier opérateur pour que vous puissiez sortir au milieu. Il suffit de le «surpasser» un peu pour le rendre plus visible -

LINE:
for (;;) {
   statements;
   last LINE if $foo;
   next LINE if /^#/;
   statements;
}

Voyons quelques points plus importants -

  • N'ayez pas peur d'utiliser des étiquettes de boucle - elles sont là pour améliorer la lisibilité et pour permettre des sauts de boucle à plusieurs niveaux. Voir l'exemple précédent.

  • Évitez d'utiliser grep () (ou map ()) ou `backticks` dans un contexte vide, c'est-à-dire lorsque vous jetez simplement leurs valeurs de retour. Ces fonctions ont toutes des valeurs de retour, alors utilisez-les. Sinon, utilisez plutôt une boucle foreach () ou la fonction system ().

  • Pour la portabilité, lorsque vous utilisez des fonctionnalités qui peuvent ne pas être implémentées sur chaque machine, testez la construction dans une évaluation pour voir si elle échoue. Si vous connaissez la version ou le niveau de patch d'une fonctionnalité particulière, vous pouvez tester $] ($ PERL_VERSION en anglais) pour voir si elle sera là. Le module Config vous permettra également d'interroger les valeurs déterminées par le programme Configure lors de l'installation de Perl.

  • Choisissez des identifiants mnémotechniques. Si vous ne vous souvenez pas de ce que signifie mnémotechnique, vous avez un problème.

  • Alors que les identifiants courts comme $ gotit sont probablement corrects, utilisez des traits de soulignement pour séparer les mots dans des identifiants plus longs. Il est généralement plus facile à lire$var_names_like_this than $VarNamesLikeThis, en particulier pour les locuteurs non natifs de l'anglais. C'est aussi une règle simple qui fonctionne de manière cohérente avec VAR_NAMES_LIKE_THIS.

  • Les noms de package font parfois exception à cette règle. Perl réserve de manière informelle des noms de modules en minuscules pour les modules "pragma" comme integer et strict. Les autres modules devraient commencer par une majuscule et utiliser une casse mixte, mais probablement sans traits de soulignement en raison des limitations dans les représentations des noms de modules par les systèmes de fichiers primitifs comme des fichiers qui doivent tenir dans quelques octets épars.

  • Si vous avez une expression régulière vraiment velue, utilisez le modificateur / x et insérez un espace pour qu'elle ressemble un peu moins au bruit de ligne. N'utilisez pas de barre oblique comme délimiteur lorsque votre expression rationnelle a des barres obliques ou des barres obliques inverses.

  • Vérifiez toujours les codes de retour des appels système. Les bons messages d'erreur doivent être envoyés à STDERR, inclure le programme à l'origine du problème, l'appel système ayant échoué et les arguments, et (TRÈS IMPORTANT) doit contenir le message d'erreur système standard indiquant ce qui n'a pas fonctionné. Voici un exemple simple mais suffisant -

opendir(D, $dir) or die "can't opendir $dir: $!";
  • Pensez à la réutilisabilité. Pourquoi gaspiller votre cerveau en un seul coup alors que vous voudrez peut-être refaire quelque chose comme ça? Pensez à généraliser votre code. Envisagez d'écrire un module ou une classe d'objets. Envisagez de faire en sorte que votre code s'exécute proprement avec use strict et utilisez les avertissements (ou -w) en vigueur. Pensez à donner votre code. Pensez à changer votre vision du monde. Considérez ... oh, tant pis.

  • Être cohérent.

  • Sois gentil.

Une expression régulière est une chaîne de caractères qui définit le ou les modèles que vous visualisez. La syntaxe des expressions régulières en Perl est très similaire à ce que vous trouverez dans d'autres programmes d'expressions régulières, tels quesed, grep, et awk.

La méthode de base pour appliquer une expression régulière consiste à utiliser les opérateurs de liaison de modèle = ~ et !~. Le premier opérateur est un opérateur de test et d'affectation.

Il existe trois opérateurs d'expressions régulières dans Perl.

  • Faire correspondre l'expression régulière - m //
  • Remplacer une expression régulière - s ///
  • Expression régulière translittérée - tr ///

Les barres obliques dans chaque cas agissent comme des délimiteurs pour l'expression régulière (regex) que vous spécifiez. Si vous êtes à l'aise avec un autre délimiteur, vous pouvez utiliser à la place de la barre oblique.

L'opérateur de match

L'opérateur de correspondance, m //, est utilisé pour faire correspondre une chaîne ou une instruction à une expression régulière. Par exemple, pour faire correspondre la séquence de caractères "foo" à la barre $ scalaire, vous pouvez utiliser une instruction comme celle-ci -

#!/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";
}

Lorsque le programme ci-dessus est exécuté, il produit le résultat suivant -

First time is matching
Second time is matching

Le m // fonctionne en fait de la même manière que la série d'opérateurs q //. Vous pouvez utiliser n'importe quelle combinaison de caractères naturellement correspondants pour servir de délimiteurs pour l'expression. Par exemple, m {}, m () et m> <sont tous valides. L'exemple ci-dessus peut donc être réécrit comme suit -

#!/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";
}

Vous pouvez omettre m de m // si les délimiteurs sont des barres obliques, mais pour tous les autres délimiteurs, vous devez utiliser le préfixe m.

Notez que toute l'expression de correspondance, c'est-à-dire l'expression à gauche de = ~ ou! ~ Et l'opérateur de correspondance, renvoie true (dans un contexte scalaire) si l'expression correspond. Par conséquent, la déclaration -

$true = ($foo =~ m/foo/);

va définir $true to 1 if $foo correspond à l'expression régulière, ou 0 si la correspondance échoue. Dans un contexte de liste, la correspondance renvoie le contenu de toutes les expressions groupées. Par exemple, lors de l'extraction des heures, des minutes et des secondes d'une chaîne de temps, nous pouvons utiliser -

my ($hours, $minutes, $seconds) = ($time =~ m/(\d+):(\d+):(\d+)/);

Match Operator Modifiers

L'opérateur de correspondance prend en charge son propre ensemble de modificateurs. Le modificateur / g permet une correspondance globale. Le modificateur / i rendra la correspondance insensible à la casse. Voici la liste complète des modificateurs

Sr.No. Modificateur et description
1

i

Rend la correspondance insensible à la casse.

2

m

Spécifie que si la chaîne contient des caractères de retour à la ligne ou de retour chariot, les opérateurs ^ et $ correspondent désormais à une limite de nouvelle ligne, au lieu d'une limite de chaîne.

3

o

Évalue l'expression une seule fois.

4

s

Permet l'utilisation de. pour correspondre à un caractère de nouvelle ligne.

5

x

Vous permet d'utiliser un espace blanc dans l'expression pour plus de clarté.

6

g

Recherche globalement toutes les correspondances.

sept

cg

Permet à la recherche de continuer même après l'échec d'une correspondance globale.

Correspondance une seule fois

Il existe également une version plus simple de l'opérateur de correspondance - le? PATTERN? opérateur. C'est fondamentalement identique à l'opérateur m // sauf qu'il ne correspond qu'une seule fois dans la chaîne que vous recherchez entre chaque appel à réinitialiser.

Par exemple, vous pouvez l'utiliser pour obtenir le premier et le dernier éléments d'une liste -

#!/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";

Lorsque le programme ci-dessus est exécuté, il produit le résultat suivant -

First: foo, Last: footbrdige

Variables d'expression régulière

Les variables d'expression régulière incluent $, qui contient tout ce que la dernière correspondance de regroupement correspond; $&, qui contient toute la chaîne correspondante; $`, qui contient tout avant la chaîne correspondante; et$', qui contient tout après la chaîne correspondante. Le code suivant montre le résultat -

#!/usr/bin/perl

$string = "The food is in the salad bar";
$string =~ m/foo/; print "Before: $`\n";
print "Matched: $&\n"; print "After: $'\n";

Lorsque le programme ci-dessus est exécuté, il produit le résultat suivant -

Before: The
Matched: foo
After: d is in the salad bar

L'opérateur de substitution

L'opérateur de substitution, s ///, n'est en réalité qu'une extension de l'opérateur de correspondance qui vous permet de remplacer le texte correspondant par un nouveau texte. La forme de base de l'opérateur est -

s/PATTERN/REPLACEMENT/;

Le PATTERN est l'expression régulière du texte que nous recherchons. Le REMPLACEMENT est une spécification du texte ou de l'expression régulière que nous voulons utiliser pour remplacer le texte trouvé par. Par exemple, nous pouvons remplacer toutes les occurrences dedog avec cat en utilisant l'expression régulière suivante -

#/user/bin/perl

$string = "The cat sat on the mat"; $string =~ s/cat/dog/;

print "$string\n";

Lorsque le programme ci-dessus est exécuté, il produit le résultat suivant -

The dog sat on the mat

Modificateurs d'opérateur de substitution

Voici la liste de tous les modificateurs utilisés avec l'opérateur de substitution.

Sr.No. Modificateur et description
1

i

Rend la correspondance insensible à la casse.

2

m

Spécifie que si la chaîne contient des caractères de retour à la ligne ou de retour chariot, les opérateurs ^ et $ correspondent désormais à une limite de nouvelle ligne, au lieu d'une limite de chaîne.

3

o

Évalue l'expression une seule fois.

4

s

Permet l'utilisation de. pour correspondre à un caractère de nouvelle ligne.

5

x

Vous permet d'utiliser un espace blanc dans l'expression pour plus de clarté.

6

g

Remplace toutes les occurrences de l'expression trouvée par le texte de remplacement.

sept

e

Évalue le remplacement comme s'il s'agissait d'une instruction Perl et utilise sa valeur de retour comme texte de remplacement.

L'opérateur de traduction

La traduction est similaire, mais pas identique, aux principes de substitution, mais contrairement à la substitution, la traduction (ou translittération) n'utilise pas d'expressions régulières pour sa recherche sur les valeurs de remplacement. Les opérateurs de traduction sont -

tr/SEARCHLIST/REPLACEMENTLIST/cds
y/SEARCHLIST/REPLACEMENTLIST/cds

La traduction remplace toutes les occurrences des caractères dans SEARCHLIST par les caractères correspondants dans REPLACEMENTLIST. Par exemple, en utilisant le "Le chat s'est assis sur le tapis". chaîne que nous avons utilisée dans ce chapitre -

#/user/bin/perl

$string = 'The cat sat on the mat'; $string =~ tr/a/o/;

print "$string\n";

Lorsque le programme ci-dessus est exécuté, il produit le résultat suivant -

The cot sot on the mot.

Des plages Perl standard peuvent également être utilisées, vous permettant de spécifier des plages de caractères par lettre ou valeur numérique. Pour changer la casse de la chaîne, vous pouvez utiliser la syntaxe suivante à la place deuc fonction.

$string =~ tr/a-z/A-Z/;

Modificateurs d'opérateurs de traduction

Voici la liste des opérateurs liés à la traduction.

Sr.No. Modificateur et description
1

c

Complète la LISTE DE RECHERCHE.

2

d

Supprime les caractères trouvés mais non remplacés.

3

s

Les écrasements dupliquent les caractères remplacés.

Le modificateur / d supprime les caractères correspondant à SEARCHLIST qui n'ont pas d'entrée correspondante dans REPLACEMENTLIST. Par exemple -

#!/usr/bin/perl 

$string = 'the cat sat on the mat.'; $string =~ tr/a-z/b/d;

print "$string\n";

Lorsque le programme ci-dessus est exécuté, il produit le résultat suivant -

b b   b.

Le dernier modificateur, / s, supprime les séquences de caractères en double qui ont été remplacées, donc -

#!/usr/bin/perl

$string = 'food';
$string = 'food'; $string =~ tr/a-z/a-z/s;

print "$string\n";

Lorsque le programme ci-dessus est exécuté, il produit le résultat suivant -

fod

Expressions régulières plus complexes

Vous n'êtes pas seulement obligé de faire correspondre des chaînes fixes. En fait, vous pouvez faire correspondre à peu près tout ce dont vous pourriez rêver en utilisant des expressions régulières plus complexes. Voici une feuille de triche rapide -

Le tableau suivant répertorie la syntaxe d'expression régulière disponible en Python.

Sr.No. Modèle et description
1

^

Correspond au début de la ligne.

2

$

Correspond à la fin de la ligne.

3

.

Correspond à n'importe quel caractère unique sauf le saut de ligne. L'utilisation de l'option m lui permet également de correspondre à la nouvelle ligne.

4

[...]

Correspond à n'importe quel caractère unique entre crochets.

5

[^...]

Correspond à n'importe quel caractère unique non entre crochets.

6

*

Correspond à 0 occurrences ou plus de l'expression précédente.

sept

+

Correspond à une ou plusieurs occurrences de l'expression précédente.

8

?

Correspond à 0 ou 1 occurrence de l'expression précédente.

9

{ n}

Correspond exactement au nombre n d'occurrences de l'expression précédente.

dix

{ n,}

Correspond à n occurrences ou plus de l'expression précédente.

11

{ n, m}

Correspond à au moins n et au plus m occurrences de l'expression précédente.

12

a| b

Correspond à a ou b.

13

\w

Correspond aux caractères des mots.

14

\W

Correspond aux caractères non-mots.

15

\s

Correspond aux espaces. Équivaut à [\ t \ n \ r \ f].

16

\S

Correspond à un espace non blanc.

17

\d

Correspond aux chiffres. Équivalent à [0-9].

18

\D

Correspond aux non-chiffres.

19

\A

Correspond au début de la chaîne.

20

\Z

Correspond à la fin de la chaîne. Si une nouvelle ligne existe, elle correspond juste avant la nouvelle ligne.

21

\z

Correspond à la fin de la chaîne.

22

\G

Correspond au point où le dernier match s'est terminé.

23

\b

Correspond aux limites des mots en dehors des crochets. Correspond à l'espace arrière (0x08) lorsqu'il est entre crochets.

24

\B

Correspond aux limites non-mot.

25

\n, \t, etc.

Correspond aux retours à la ligne, aux retours chariot, aux tabulations, etc.

26

\1...\9

Correspond à la nième sous-expression groupée.

27

\10

Correspond à la nième sous-expression groupée si elle correspond déjà. Sinon, fait référence à la représentation octale d'un code de caractère.

28

[aeiou]

Correspond à un seul caractère dans l'ensemble donné

29

[^aeiou]

Correspond à un seul caractère en dehors de l'ensemble donné

Le métacaractère ^ correspond au début de la chaîne et le $ metasymbol correspond à la fin de la chaîne. Voici quelques brefs exemples.

# 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+$/

Jetons un œil à un autre exemple.

#!/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";

Lorsque le programme ci-dessus est exécuté, il produit le résultat suivant -

First word: Cats
Line starts: Cats When

Correspondance des limites

le \bcorrespond à n'importe quelle limite de mot, comme défini par la différence entre la classe \ w et la classe \ W. Parce que \ w inclut les caractères d'un mot, et \ W le contraire, cela signifie normalement la fin d'un mot. le\Bl'assertion correspond à toute position qui n'est pas une limite de mot. Par exemple -

/\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'

Sélection d'alternatives

Le | caractère est exactement comme le OU standard ou au niveau du bit dans Perl. Il spécifie des correspondances alternatives dans une expression régulière ou un groupe. Par exemple, pour faire correspondre "chat" ou "chien" dans une expression, vous pouvez utiliser ceci -

if ($string =~ /cat|dog/)

Vous pouvez regrouper des éléments individuels d'une expression afin de prendre en charge des correspondances complexes. La recherche des noms de deux personnes pourrait être réalisée avec deux tests distincts, comme celui-ci -

if (($string =~ /Martin Brown/) ||  ($string =~ /Sharon Brown/)) This could be written as follows if ($string =~ /(Martin|Sharon) Brown/)

Correspondance de regroupement

Du point de vue des expressions régulières, il n'y a pas de différence entre, sauf peut-être que la première est légèrement plus claire.

$string =~ /(\S+)\s+(\S+)/; and $string =~ /\S+\s+\S+/;

Cependant, l'avantage du regroupement est qu'il nous permet d'extraire une séquence d'une expression régulière. Les regroupements sont renvoyés sous forme de liste dans l'ordre dans lequel ils apparaissent dans l'original. Par exemple, dans le fragment suivant, nous avons extrait les heures, les minutes et les secondes d'une chaîne.

my ($hours, $minutes, $seconds) = ($time =~ m/(\d+):(\d+):(\d+)/);

En plus de cette méthode directe, les groupes correspondants sont également disponibles dans les variables spéciales $ x, où x est le numéro du groupe dans l'expression régulière. On pourrait donc réécrire l'exemple précédent comme suit -

#!/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";

Lorsque le programme ci-dessus est exécuté, il produit le résultat suivant -

Hours : 12, Minutes: 05, Second: 30

Lorsque des groupes sont utilisés dans des expressions de substitution, la syntaxe $ x peut être utilisée dans le texte de remplacement. Ainsi, nous pourrions reformater une chaîne de date en utilisant ceci -

#!/usr/bin/perl

$date = '03/26/1999';
$date =~ s#(\d+)/(\d+)/(\d+)#$3/$1/$2#;

print "$date\n";

Lorsque le programme ci-dessus est exécuté, il produit le résultat suivant -

1999/03/26

L'assertion \ G

L'assertion \ G vous permet de continuer la recherche à partir du point où la dernière correspondance s'est produite. Par exemple, dans le code suivant, nous avons utilisé \ G pour que nous puissions rechercher la bonne position, puis extraire des informations, sans avoir à créer une expression régulière unique plus complexe -

#!/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";

Lorsque le programme ci-dessus est exécuté, il produit le résultat suivant -

Time: 12:31:02, Date: 4/12/00

L'assertion \ G n'est en fait que l'équivalent métasymbole de la fonction pos, donc entre les appels d'expression régulière, vous pouvez continuer à utiliser pos, et même modifier la valeur de pos (et donc \ G) en utilisant pos comme sous-programme lvalue.

Exemples d'expressions régulières

Caractères littéraux

Sr.No. Exemple et description
1

Perl

Correspond à "Perl".

Classes de personnages

Sr.No. Exemple et description
1

[Pp]ython

Correspond à "Python" ou "python"

2

rub[ye]

Correspond à "ruby" ou "rube"

3

[aeiou]

Correspond à n'importe quelle voyelle minuscule

4

[0-9]

Correspond à n'importe quel chiffre; identique à [0123456789]

5

[a-z]

Correspond à n'importe quelle lettre ASCII minuscule

6

[A-Z]

Correspond à n'importe quelle lettre ASCII majuscule

sept

[a-zA-Z0-9]

Correspond à l'un des éléments ci-dessus

8

[^aeiou]

Correspond à tout autre chose qu'une voyelle minuscule

9

[^0-9]

Correspond à autre chose qu'un chiffre

Classes de caractères spéciaux

Sr.No. Exemple et description
1

.

Correspond à n'importe quel caractère sauf le saut de ligne

2

\d

Correspond à un chiffre: [0-9]

3

\D

Correspond à un non-chiffre: [^ 0-9]

4

\s

Correspond à un caractère d'espacement: [\ t \ r \ n \ f]

5

\S

Correspond à un espace non blanc: [^ \ t \ r \ n \ f]

6

\w

Correspond à un caractère de mot unique: [A-Za-z0-9_]

sept

\W

Correspond à un caractère non-mot: [^ A-Za-z0-9_]

Cas de répétition

Sr.No. Exemple et description
1

ruby?

Correspond à "rub" ou "ruby": le y est facultatif

2

ruby*

Correspond à "frotter" plus 0 ou plus de y

3

ruby+

Correspond à "frotter" plus 1 ou plus de y

4

\d{3}

Correspond exactement à 3 chiffres

5

\d{3,}

Correspond à 3 chiffres ou plus

6.

\d{3,5}

Correspond à 3, 4 ou 5 chiffres

Répétition sans réverbération

Cela correspond au plus petit nombre de répétitions -

Sr.No. Exemple et description
1

<.*>

Répétition gourmande: correspond à "<python> perl>"

2

<.*?>

Nongreedy: correspond à "<python>" dans "<python> perl>"

Regroupement avec des parenthèses

Sr.No. Exemple et description
1

\D\d+

Aucun groupe: + répète \ d

2

(\D\d)+

Groupé: + répète \ D \ d paire

3

([Pp]ython(, )?)+

Faites correspondre "Python", "Python, python, python", etc.

Références arrière

Cela correspond à nouveau à un groupe précédemment apparié -

Sr.No. Exemple et description
1

([Pp])ython&\1ails

Compatible avec python et seaux ou Python et seaux

2

(['"])[^\1]*\1

Chaîne entre guillemets simples ou doubles. \ 1 correspond quel que soit le premier groupe correspondant. \ 2 correspond quel que soit le 2e groupe, etc.

Alternatives

Sr.No. Exemple et description
1

python|perl

Correspond à "python" ou "perl"

2

rub(y|le))

Correspond à "ruby" ou "rouble"

3

Python(!+|\?)

"Python" suivi d'un ou plusieurs! ou un ?

Ancres

Ce besoin de spécifier les positions de correspondance.

Sr.No. Exemple et description
1

^Python

Correspond à "Python" au début d'une chaîne ou d'une ligne interne

2

Python$

Correspond à "Python" à la fin d'une chaîne ou d'une ligne

3

\APython

Correspond à "Python" au début d'une chaîne

4

Python\Z

Correspond à "Python" à la fin d'une chaîne

5

\bPython\b

Correspond à "Python" à la limite d'un mot

6

\brub\B

\ B n'est pas une limite de mot: correspond à "frotter" dans "rube" et "ruby" mais pas seul

sept

Python(?=!)

Correspond à "Python", s'il est suivi d'un point d'exclamation

8

Python(?!!)

Correspond à "Python", s'il n'est pas suivi d'un point d'exclamation

Syntaxe spéciale avec parenthèses

Sr.No. Exemple et description
1

R(?#comment)

Correspond à "R". Tout le reste est un commentaire

2

R(?i)uby

Insensible à la casse tout en correspondant à "uby"

3

R(?i:uby)

Comme ci-dessus

4

rub(?:y|le))

Grouper uniquement sans créer \ 1 backreference

Utilisation de l'utilitaire sendmail

Envoi d'un message clair

Si vous travaillez sur une machine Linux / Unix, vous pouvez simplement utiliser sendmailutilitaire dans votre programme Perl pour envoyer des e-mails. Voici un exemple de script permettant d'envoyer un e-mail à un identifiant d'e-mail donné. Assurez-vous simplement que le chemin indiqué pour l'utilitaire sendmail est correct. Cela peut être différent pour votre machine 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";

En fait, le script ci-dessus est un script de courrier électronique client, qui rédigera le courrier électronique et le soumettra au serveur fonctionnant localement sur votre machine Linux / Unix. Ce script ne sera pas responsable de l'envoi des e-mails à la destination réelle. Vous devez donc vous assurer que le serveur de messagerie est correctement configuré et fonctionne sur votre machine pour envoyer un courrier électronique à l'ID de messagerie donné.

Envoi d'un message HTML

Si vous souhaitez envoyer un e-mail au format HTML à l'aide de sendmail, il vous suffit d'ajouter Content-type: text/html\n dans la partie en-tête de l'e-mail comme suit -

#!/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";

Utilisation du module MIME :: Lite

Si vous travaillez sur une machine Windows, vous n'aurez pas accès à l'utilitaire sendmail. Mais vous avez une alternative pour écrire votre propre client de messagerie en utilisant le module perl MIME: Lite. Vous pouvez télécharger ce module depuis MIME-Lite-3.01.tar.gz et l'installer sur votre machine Windows ou Linux / Unix. Pour l'installer, suivez les étapes simples -

$tar xvfz MIME-Lite-3.01.tar.gz
$cd MIME-Lite-3.01 $perl Makefile.PL
$make $make install

Voilà et vous aurez le module MIME :: Lite installé sur votre machine. Vous êtes maintenant prêt à envoyer votre e-mail avec des scripts simples expliqués ci-dessous.

Envoi d'un message clair

Voici maintenant un script qui se chargera d'envoyer un e-mail à l'ID d'e-mail donné -

#!/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";

Envoi d'un message HTML

Si vous souhaitez envoyer un e-mail au format HTML à l'aide de sendmail, il vous suffit d'ajouter Content-type: text/html\ndans la partie d'en-tête de l'e-mail. Voici le script, qui se chargera d'envoyer un e-mail au format 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";

Envoi d'une pièce jointe

Si vous souhaitez envoyer une pièce jointe, le script suivant sert le but -

#!/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";

Vous pouvez joindre autant de fichiers que vous le souhaitez dans votre e-mail en utilisant la méthode attach ().

Utilisation du serveur SMTP

Si votre machine n'exécute pas de serveur de messagerie, vous pouvez utiliser tout autre serveur de messagerie disponible sur le site distant. Mais pour utiliser tout autre serveur de messagerie, vous devrez avoir un identifiant, son mot de passe, URL, etc. Une fois que vous avez toutes les informations requises, il vous suffit de fournir ces informations danssend() méthode comme suit -

$msg->send('smtp', "smtp.myisp.net", AuthUser=>"id", AuthPass=>"password" );

Vous pouvez contacter l'administrateur de votre serveur de messagerie pour avoir les informations utilisées ci-dessus et si un identifiant d'utilisateur et un mot de passe ne sont pas déjà disponibles, votre administrateur peut les créer en quelques minutes.

Qu'est-ce qu'une prise?

Socket est un mécanisme Berkeley UNIX de création d'une connexion duplex virtuelle entre différents processus. Cela a ensuite été porté sur tous les systèmes d'exploitation connus permettant la communication entre les systèmes à travers l'emplacement géographique fonctionnant sur différents logiciels OS. Sans la prise, la plupart des communications réseau entre les systèmes ne se seraient jamais produites.

Regardant de plus près; un système informatique typique sur un réseau reçoit et envoie les informations souhaitées par les diverses applications qui y sont exécutées. Ces informations sont acheminées vers le système, car une adresse IP unique lui est attribuée. Sur le système, ces informations sont données aux applications concernées, qui écoutent sur différents ports. Par exemple, un navigateur Internet écoute sur le port 80 les informations reçues du serveur Web. Nous pouvons également écrire nos applications personnalisées qui peuvent écouter et envoyer / recevoir des informations sur un numéro de port spécifique.

Pour l'instant, résumons qu'une socket est une adresse IP et un port, permettant à la connexion d'envoyer et de recevoir des données sur un réseau.

Pour expliquer le concept de socket mentionné ci-dessus, nous prendrons un exemple de programmation client-serveur utilisant Perl. Pour compléter une architecture client-serveur, nous devrions suivre les étapes suivantes -

Pour créer un serveur

  • Créer une socket en utilisant socket appel.

  • Liez le socket à une adresse de port en utilisant bind appel.

  • Écoutez la prise à l'adresse du port en utilisant listen appel.

  • Accepter les connexions client avec accept appel.

Pour créer un client

  • Créer une socket avec socket appel.

  • Connectez (le socket) au serveur en utilisant connect appel.

Le diagramme suivant montre la séquence complète des appels utilisés par le client et le serveur pour communiquer entre eux -

Appels de socket côté serveur

L'appel socket ()

le socket()appel est le premier appel à établir une connexion réseau crée une socket. Cet appel a la syntaxe suivante -

socket( SOCKET, DOMAIN, TYPE, PROTOCOL );

L'appel ci-dessus crée un SOCKET et les trois autres arguments sont des entiers qui doivent avoir les valeurs suivantes pour les connexions TCP / IP.

  • DOMAINdevrait être PF_INET. C'est probable 2 sur votre ordinateur.

  • TYPE doit être SOCK_STREAM pour la connexion TCP / IP.

  • PROTOCOL devrait être (getprotobyname('tcp'))[2]. C'est le protocole particulier tel que TCP à parler sur le socket.

Donc, l'appel de la fonction socket émis par le serveur sera quelque chose comme ceci -

use Socket     # This defines PF_INET and SOCK_STREAM

socket(SOCKET,PF_INET,SOCK_STREAM,(getprotobyname('tcp'))[2]);

L'appel bind ()

Les sockets créés par l'appel socket () sont inutiles tant qu'ils ne sont pas liés à un nom d'hôte et à un numéro de port. Le serveur utilise les éléments suivantsbind() pour spécifier le port sur lequel ils accepteront les connexions des clients.

bind( SOCKET, ADDRESS );

Ici SOCKET est le descripteur renvoyé par l'appel socket () et ADDRESS est une adresse socket (pour TCP / IP) contenant trois éléments -

  • La famille d'adresses (pour TCP / IP, c'est AF_INET, probablement 2 sur votre système).

  • Le numéro de port (par exemple 21).

  • L'adresse Internet de l'ordinateur (par exemple 10.12.12.168).

Comme le bind () est utilisé par un serveur, qui n'a pas besoin de connaître sa propre adresse, la liste d'arguments ressemble à ceci -

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";

le or die est très importante car si un serveur meurt sans connexions en suspens, le port ne sera pas immédiatement réutilisable à moins que vous n'utilisiez l'option SO_REUSEADDR en utilisant setsockopt()fonction. Icipack_sockaddr_in() La fonction est utilisée pour emballer le port et l'adresse IP au format binaire.

L'appel listen ()

S'il s'agit d'un programme serveur, il est nécessaire d'émettre un appel à listen()sur le port spécifié pour écouter, c'est-à-dire attendre les demandes entrantes. Cet appel a la syntaxe suivante -

listen( SOCKET, QUEUESIZE );

L'appel ci-dessus utilise le descripteur SOCKET retourné par l'appel socket () et QUEUESIZE est le nombre maximum de demandes de connexion en attente autorisées simultanément.

L'appel accept ()

S'il s'agit d'un programme serveur, il est nécessaire d'émettre un appel au access()fonction pour accepter les connexions entrantes. Cet appel a la syntaxe suivante -

accept( NEW_SOCKET, SOCKET );

L'appel d'acceptation reçoit le descripteur SOCKET retourné par la fonction socket () et une fois terminé, un nouveau descripteur de socket NEW_SOCKET est renvoyé pour toutes les communications futures entre le client et le serveur. Si l'appel d'accès () échoue, il retourne FLASE qui est défini dans le module Socket que nous avons utilisé initialement.

Généralement, accept () est utilisé dans une boucle infinie. Dès qu'une connexion arrive, le serveur crée un processus enfant pour la traiter ou la sert lui-même, puis revient pour écouter d'autres connexions.

while(1) {
   accept( NEW_SOCKET, SOCKT );
   .......
}

Maintenant tous les appels liés au serveur sont terminés et voyons un appel qui sera demandé par le client.

Appels de socket côté client

L'appel connect ()

Si vous allez préparer le programme client, vous utiliserez d'abord socket() appelez pour créer une socket et vous devrez alors utiliser connect()appelez pour vous connecter au serveur. Vous avez déjà vu la syntaxe d'appel socket () et elle restera similaire à l'appel serveur socket (), mais voici la syntaxe pourconnect() appeler -

connect( SOCKET, ADDRESS );

Ici, SCOKET est le descripteur de socket renvoyé par l'appel socket () émis par le client et ADDRESS est une adresse de socket similaire à l' appel de liaison , sauf qu'elle contient l'adresse IP du serveur distant.

$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";

Si vous vous connectez avec succès au serveur, vous pouvez commencer à envoyer vos commandes au serveur à l'aide du descripteur SOCKET, sinon votre client sortira en donnant un message d'erreur.

Client - Exemple de serveur

Voici un code Perl pour implémenter un simple programme client-serveur utilisant le socket Perl. Ici, le serveur écoute les demandes entrantes et une fois la connexion établie, il répond simplement à Smile depuis le serveur . Le client lit ce message et l'imprime à l'écran. Voyons comment cela a été fait, en supposant que nous avons notre serveur et notre client sur la même machine.

Script pour créer un serveur

#!/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;
}

Pour exécuter le serveur en mode arrière-plan, exécutez la commande suivante à l'invite Unix -

$perl sever.pl&

Script pour créer un client

!/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: $!";

Maintenant, démarrons notre client à l'invite de commande, qui se connectera au serveur et lira le message envoyé par le serveur et affichera la même chose à l'écran comme suit -

$perl client.pl
Smile from the server

NOTE - Si vous donnez l'adresse IP réelle en notation par points, il est recommandé de fournir une adresse IP dans le même format à la fois sur le client et sur le serveur pour éviter toute confusion.

Nous avons déjà étudié les références dans les tableaux et hachages anonymes Perl et Perl. Le concept orienté objet en Perl est très basé sur des références, des tableaux et des hachages anonymes. Commençons par apprendre les concepts de base de Perl orienté objet.

Principes de base des objets

Il existe trois termes principaux, expliqués du point de vue de la manière dont Perl gère les objets. Les termes sont objet, classe et méthode.

  • Un objectdans Perl est simplement une référence à un type de données qui sait à quelle classe il appartient. L'objet est stocké comme référence dans une variable scalaire. Étant donné qu'un scalaire ne contient qu'une référence à l'objet, le même scalaire peut contenir différents objets dans différentes classes.

  • UNE class dans Perl est un package qui contient les méthodes correspondantes requises pour créer et manipuler des objets.

  • UNE methoddans Perl est un sous-programme, défini avec le paquet. Le premier argument de la méthode est une référence d'objet ou un nom de package, selon que la méthode affecte l'objet courant ou la classe.

Perl fournit un bless() function, qui est utilisée pour renvoyer une référence qui devient finalement un objet.

Définition d'une classe

Il est très simple de définir une classe en Perl. Une classe correspond à un package Perl dans sa forme la plus simple. Pour créer une classe en Perl, nous construisons d'abord un package.

Un package est une unité autonome de variables et de sous-programmes définis par l'utilisateur, qui peut être réutilisée encore et encore.

Les packages Perl fournissent un espace de noms séparé au sein d'un programme Perl qui empêche les sous-programmes et les variables d'être en conflit avec ceux des autres packages.

Pour déclarer une classe nommée Person en Perl, nous faisons -

package Person;

La portée de la définition de package s'étend jusqu'à la fin du fichier ou jusqu'à ce qu'un autre mot-clé de package soit rencontré.

Créer et utiliser des objets

Pour créer une instance d'une classe (un objet), nous avons besoin d'un constructeur d'objet. Ce constructeur est une méthode définie dans le package. La plupart des programmeurs choisissent de nommer cette méthode de constructeur d'objet comme nouvelle, mais en Perl, vous pouvez utiliser n'importe quel nom.

Vous pouvez utiliser n'importe quel type de variable Perl comme objet en Perl. La plupart des programmeurs Perl choisissent des références à des tableaux ou des hachages.

Créons notre constructeur pour notre classe Person en utilisant une référence de hachage Perl. Lors de la création d'un objet, vous devez fournir un constructeur, qui est un sous-programme dans un package qui renvoie une référence d'objet. La référence d'objet est créée en bénissant une référence à la classe du package. Par exemple -

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;
}

Voyons maintenant comment créer un objet.

$object = new Person( "Mohammad", "Saleem", 23234345);

Vous pouvez utiliser un hachage simple dans votre consturctor si vous ne souhaitez attribuer aucune valeur à une variable de classe. Par exemple -

package Person;
sub new {
   my $class = shift; my $self = {};
   bless $self, $class;
   return $self;
}

Définition des méthodes

D'autres langages orientés objet ont le concept de sécurité des données pour empêcher un programmeur de modifier directement les données d'un objet et ils fournissent des méthodes d'accès pour modifier les données d'objet. Perl n'a pas de variables privées mais nous pouvons toujours utiliser le concept de méthodes d'assistance pour manipuler les données d'objets.

Permet de définir une méthode d'assistance pour obtenir le prénom de la personne -

sub getFirstName {
   return $self->{_firstName};
}

Une autre fonction d'aide pour définir le prénom de la personne -

sub setFirstName {
   my ( $self, $firstName ) = @_;
   $self->{_firstName} = $firstName if defined($firstName); return $self->{_firstName};
}

Jetons maintenant un coup d'œil à l'exemple complet: le package Keep Person et les fonctions d'assistance dans le fichier 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;

Utilisons maintenant l'objet Person dans le fichier employee.pl comme suit -

#!/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";

Lorsque nous exécutons le programme ci-dessus, cela produit le résultat suivant -

First Name is Mohammad
Last Name is Saleem
SSN is 23234345
Before Setting First Name is : Mohammad
Before Setting First Name is : Mohd.

Héritage

La programmation orientée objet a un concept très bon et utile appelé héritage. L'héritage signifie simplement que les propriétés et méthodes d'une classe parent seront disponibles pour les classes enfants. Vous n'avez donc pas besoin d'écrire le même code encore et encore, vous pouvez simplement hériter d'une classe parent.

Par exemple, nous pouvons avoir une classe Employee, qui hérite de Person. C'est ce qu'on appelle une relation «isa» car un employé est une personne. Perl a une variable spéciale, @ISA, pour vous aider. @ISA régit l'héritage (de méthode).

Voici les points importants à considérer lors de l'utilisation de l'héritage -

  • Perl recherche dans la classe de l'objet spécifié la méthode ou l'attribut donné, c'est-à-dire une variable.

  • Perl recherche les classes définies dans le tableau @ISA de la classe d'objets.

  • Si aucune méthode n'est trouvée dans les étapes 1 ou 2, alors Perl utilise un sous-programme AUTOLOAD, s'il en trouve un dans l'arborescence @ISA.

  • Si une méthode correspondante ne peut toujours pas être trouvée, Perl recherche la méthode dans la classe UNIVERSAL (package) qui fait partie de la bibliothèque Perl standard.

  • Si la méthode n'a toujours pas été trouvée, Perl abandonne et lève une exception d'exécution.

Donc, pour créer une nouvelle classe Employee qui héritera des méthodes et des attributs de notre classe Person, nous codons simplement comme suit: Conservez ce code dans Employee.pm.

#!/usr/bin/perl

package Employee;
use Person;
use strict;
our @ISA = qw(Person);    # inherits from Person

Maintenant, Employee Class a toutes les méthodes et attributs hérités de la classe Person et vous pouvez les utiliser comme suit: Utilisez le fichier main.pl pour le tester -

#!/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";

Lorsque nous exécutons le programme ci-dessus, cela produit le résultat suivant -

First Name is Mohammad
Last Name is Saleem
SSN is 23234345
Before Setting First Name is : Mohammad
Before Setting First Name is : Mohd.

Remplacement de méthode

La classe enfant Employee hérite de toutes les méthodes de la classe parente Person. Mais si vous souhaitez remplacer ces méthodes dans votre classe enfant, vous pouvez le faire en donnant votre propre implémentation. Vous pouvez ajouter vos fonctions supplémentaires dans la classe enfant ou vous pouvez ajouter ou modifier la fonctionnalité d'une méthode existante dans sa classe parent. Cela peut être fait comme suit: modifier le fichier 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;

Maintenant, essayons à nouveau d'utiliser l'objet Employee dans notre fichier main.pl et exécutons-le.

#!/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";

Lorsque nous exécutons le programme ci-dessus, cela produit le résultat suivant -

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.

Chargement automatique par défaut

Perl offre une fonctionnalité que vous ne trouverez dans aucun autre langage de programmation: un sous-programme par défaut. Ce qui signifie que si vous définissez une fonction appeléeAUTOLOAD(),alors tout appel à des sous-programmes non définis appellera automatiquement la fonction AUTOLOAD (). Le nom du sous-programme manquant est accessible dans ce sous-programme sous la forme $ AUTOLOAD.

La fonctionnalité de chargement automatique par défaut est très utile pour la gestion des erreurs. Voici un exemple pour implémenter AUTOLOAD, vous pouvez implémenter cette fonction à votre manière.

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);
   }
}

Destructeurs et collecte des ordures

Si vous avez déjà programmé à l'aide de la programmation orientée objet, vous serez conscient de la nécessité de créer un destructorpour libérer la mémoire allouée à l'objet lorsque vous avez fini de l'utiliser. Perl le fait automatiquement pour vous dès que l'objet sort de la portée.

Si vous souhaitez implémenter votre destructeur, qui devrait prendre soin de fermer les fichiers ou d'effectuer un traitement supplémentaire, vous devez définir une méthode spéciale appelée DESTROY. Cette méthode sera appelée sur l'objet juste avant que Perl ne libère la mémoire qui lui est allouée. À tous les autres égards, la méthode DESTROY est comme n'importe quelle autre méthode, et vous pouvez implémenter la logique de votre choix dans cette méthode.

Une méthode destructrice est simplement une fonction membre (sous-programme) nommée DESTROY, qui sera appelée automatiquement dans les cas suivants -

  • Lorsque la variable de la référence d'objet est hors de portée.
  • Lorsque la variable de la référence d'objet n'est pas définie.
  • Lorsque le script se termine
  • Quand l'interpréteur perl se termine

Par exemple, vous pouvez simplement mettre la méthode DESTROY suivante dans votre classe -

package MyClass;
...
sub DESTROY {
   print "MyClass::DESTROY called\n";
}

Exemple de Perl orienté objet

Voici un autre bel exemple qui vous aidera à comprendre les concepts orientés objet de Perl. Mettez ce code source dans n'importe quel fichier perl et exécutez-le.

#!/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

Lorsque nous exécutons le programme ci-dessus, cela produit le résultat suivant -

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

Ce chapitre vous apprend comment accéder à une base de données dans votre script Perl. À partir de Perl 5, il est devenu très facile d'écrire des applications de base de données en utilisantDBImodule. DBI signifieDatabase Independent Interface pour Perl, ce qui signifie que DBI fournit une couche d'abstraction entre le code Perl et la base de données sous-jacente, vous permettant de changer d'implémentation de base de données très facilement.

Le DBI est un module d'accès à la base de données pour le langage de programmation Perl. Il fournit un ensemble de méthodes, variables et conventions qui fournissent une interface de base de données cohérente, indépendante de la base de données réelle utilisée.

Architecture d'une application DBI

DBI est indépendant de toute base de données disponible en backend. Vous pouvez utiliser DBI si vous travaillez avec Oracle, MySQL ou Informix, etc. Cela ressort clairement du diagramme d'archivage suivant.

Ici, DBI est responsable de prendre toutes les commandes SQL via l'API (c'est-à-dire l'interface de programmation d'application) et de les envoyer au pilote approprié pour une exécution réelle. Et enfin, DBI est responsable de prendre les résultats du pilote et de les restituer au scritp appelant.

Notation et conventions

Tout au long de ce chapitre, les notations suivantes seront utilisées et il est recommandé de suivre également la même convention.

$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

Connexion à la base de données

En supposant que nous allons travailler avec la base de données MySQL. Avant de vous connecter à une base de données, assurez-vous des points suivants. Vous pouvez utiliser notre didacticiel MySQL au cas où vous ne sauriez pas comment créer une base de données et des tables dans la base de données MySQL.

  • Vous avez créé une base de données avec un nom TESTDB.

  • Vous avez créé une table avec un nom TEST_TABLE dans TESTDB.

  • Cette table contient les champs FIRST_NAME, LAST_NAME, AGE, SEX et INCOME.

  • L'ID utilisateur "testuser" et le mot de passe "test123" sont définis pour accéder à TESTDB.

  • Le module Perl DBI est correctement installé sur votre machine.

  • Vous avez parcouru le didacticiel MySQL pour comprendre les bases de MySQL.

Voici l'exemple de connexion avec la base de données 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;

Si une connexion est établie avec la source de données, un handle de base de données est renvoyé et enregistré dans $ dbh pour une utilisation ultérieure, sinon $ dbh est défini sur une valeur undef et $ DBI :: errstr renvoie une chaîne d'erreur.

Opération INSERT

L'opération INSERT est requise lorsque vous souhaitez créer des enregistrements dans une table. Ici, nous utilisons la table TEST_TABLE pour créer nos enregistrements. Ainsi, une fois notre connexion à la base de données établie, nous sommes prêts à créer des enregistrements dans TEST_TABLE. Voici la procédure pour créer un enregistrement unique dans TEST_TABLE. Vous pouvez créer autant d'enregistrements que vous le souhaitez en utilisant le même concept.

La création d'un enregistrement prend les étapes suivantes -

  • Préparation de l'instruction SQL avec l'instruction INSERT. Cela se fera en utilisantprepare() API.

  • Exécution d'une requête SQL pour sélectionner tous les résultats de la base de données. Cela se fera en utilisantexecute() API.

  • Libération de la poignée de déclaration. Cela se fera en utilisantfinish() API.

  • Si tout va bien alors commit cette opération sinon vous pouvez rollbacktransaction complète. La validation et la restauration sont expliquées dans les sections suivantes.

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;

Utilisation des valeurs de liaison

Il peut y avoir un cas où les valeurs à saisir ne sont pas données à l'avance. Vous pouvez donc utiliser des variables de liaison qui prendront les valeurs requises au moment de l'exécution. Les modules Perl DBI utilisent un point d'interrogation à la place de la valeur réelle, puis les valeurs réelles sont transmises via l'API execute () au moment de l'exécution. Voici l'exemple -

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;

LIRE l'opération

LIRE L'opération sur n'importe quelle base de données signifie récupérer des informations utiles de la base de données, c'est-à-dire un ou plusieurs enregistrements d'une ou plusieurs tables. Ainsi, une fois notre connexion à la base de données établie, nous sommes prêts à effectuer une requête dans cette base de données. Voici la procédure pour interroger tous les enregistrements ayant un âge supérieur à 20. Cela prendra quatre étapes -

  • Préparation de la requête SQL SELECT en fonction des conditions requises. Cela se fera en utilisantprepare() API.

  • Exécution d'une requête SQL pour sélectionner tous les résultats de la base de données. Cela se fera en utilisantexecute() API.

  • Récupérer tous les résultats un par un et imprimer ces résultats. Cela se fera en utilisant fetchrow_array() API.

  • Libération de la poignée de déclaration. Cela se fera en utilisantfinish() 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();

Utilisation des valeurs de liaison

Il peut y avoir un cas où la condition n'est pas donnée à l'avance. Vous pouvez donc utiliser des variables de liaison, qui prendront les valeurs requises au moment de l'exécution. Les modules Perl DBI utilisent un point d'interrogation à la place de la valeur réelle, puis les valeurs réelles sont transmises via l'API execute () au moment de l'exécution. Voici l'exemple -

$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();

Opération UPDATE

UPDATE L'opération sur n'importe quelle base de données signifie mettre à jour un ou plusieurs enregistrements déjà disponibles dans les tables de la base de données. Voici la procédure pour mettre à jour tous les enregistrements ayant SEX comme «M». Ici, nous augmenterons l'âge de tous les hommes d'un an. Cela prendra trois étapes -

  • Préparation de la requête SQL en fonction des conditions requises. Cela se fera en utilisantprepare() API.

  • Exécution d'une requête SQL pour sélectionner tous les résultats de la base de données. Cela se fera en utilisantexecute() API.

  • Libération de la poignée de déclaration. Cela se fera en utilisantfinish() API.

  • Si tout va bien alors commit cette opération sinon vous pouvez rollbacktransaction complète. Voir la section suivante pour les API de validation et de restauration.

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;

Utilisation des valeurs de liaison

Il peut y avoir un cas où la condition n'est pas donnée à l'avance. Vous pouvez donc utiliser des variables de liaison, qui prendront les valeurs requises au moment de l'exécution. Les modules Perl DBI utilisent un point d'interrogation à la place de la valeur réelle, puis les valeurs réelles sont transmises via l'API execute () au moment de l'exécution. Voici l'exemple -

$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;

Dans certains cas, vous souhaitez définir une valeur, qui n'est pas donnée à l'avance afin que vous puissiez utiliser la valeur de liaison comme suit. Dans cet exemple, le revenu de tous les hommes sera défini sur 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();

Effacer l'opération

L'opération DELETE est requise lorsque vous souhaitez supprimer certains enregistrements de votre base de données. Voici la procédure pour supprimer tous les enregistrements de TEST_TABLE où AGE est égal à 30. Cette opération exécutera les étapes suivantes.

  • Préparation de la requête SQL en fonction des conditions requises. Cela se fera en utilisantprepare() API.

  • Exécution d'une requête SQL pour supprimer les enregistrements requis de la base de données. Cela se fera en utilisantexecute() API.

  • Libération de la poignée de déclaration. Cela se fera en utilisantfinish() API.

  • Si tout va bien alors commit cette opération sinon vous pouvez rollback transaction complète.

$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;

Utilisation de l'instruction do

Si vous effectuez une UPDATE, INSERT ou DELETE, aucune donnée ne revient de la base de données, il existe donc un raccourci pour effectuer cette opération. Vous pouvez utiliserdo instruction pour exécuter l'une des commandes comme suit.

$dbh->do('DELETE FROM TEST_TABLE WHERE age =30');

dorenvoie une valeur vraie en cas de succès et une valeur fausse en cas d'échec. En fait, s'il réussit, il renvoie le nombre de lignes affectées. Dans l'exemple, il renverrait le nombre de lignes qui ont été réellement supprimées.

Opération COMMIT

Valider est l'opération qui donne un signal vert à la base de données pour finaliser les modifications et après cette opération, aucune modification ne peut revenir à sa position d'origine.

Voici un exemple simple à appeler commit API.

$dbh->commit or die $dbh->errstr;

Fonctionnement ROLLBACK

Si vous n'êtes pas satisfait de toutes les modifications ou si vous rencontrez une erreur entre les opérations, vous pouvez annuler ces modifications pour les utiliser rollback API.

Voici un exemple simple à appeler rollback API.

$dbh->rollback or die $dbh->errstr;

Commencer la transaction

De nombreuses bases de données prennent en charge les transactions. Cela signifie que vous pouvez faire tout un tas de requêtes qui modifieraient les bases de données, mais aucune des modifications n'est réellement effectuée. Puis à la fin, vous émettez la requête SQL spécialeCOMMIT, et toutes les modifications sont effectuées simultanément. Vous pouvez également lancer la requête ROLLBACK, auquel cas toutes les modifications sont supprimées et la base de données reste inchangée.

Module Perl DBI fourni begin_workAPI, qui active les transactions (en désactivant AutoCommit) jusqu'au prochain appel de validation ou de restauration. Après la prochaine validation ou restauration, AutoCommit sera automatiquement réactivé.

$rc  = $dbh->begin_work or die $dbh->errstr;

Option de validation automatique

Si vos transactions sont simples, vous pouvez vous éviter d'avoir à émettre beaucoup de commits. Lorsque vous effectuez l'appel de connexion, vous pouvez spécifier unAutoCommitoption qui effectuera une opération de validation automatique après chaque requête réussie. Voici à quoi ça ressemble -

my $dbh = DBI->connect($dsn, $userid, $password,
              {AutoCommit => 1}) 
              or die $DBI::errstr;

Ici, AutoCommit peut prendre la valeur 1 ou 0, où 1 signifie qu'AutoCommit est activé et 0 signifie qu'AutoCommit est désactivé.

Traitement automatique des erreurs

Lorsque vous effectuez l'appel de connexion, vous pouvez spécifier une option RaiseErrors qui gère automatiquement les erreurs. Lorsqu'une erreur se produit, DBI abandonne votre programme au lieu de renvoyer un code d'erreur. Si tout ce que vous voulez, c'est abandonner le programme en cas d'erreur, cela peut être pratique. Voici à quoi ça ressemble -

my $dbh = DBI->connect($dsn, $userid, $password, {RaiseError => 1}) or die $DBI::errstr;

Ici, RaiseError peut prendre la valeur 1 ou 0.

Déconnexion de la base de données

Pour déconnecter la connexion à la base de données, utilisez disconnect API comme suit -

$rc = $dbh->disconnect  or warn $dbh->errstr;

Le comportement de transaction de la méthode de déconnexion est, malheureusement, indéfini. Certains systèmes de base de données (tels qu'Oracle et Ingres) valideront automatiquement toutes les modifications en suspens, mais d'autres (comme Informix) annuleront toutes les modifications en suspens. Les applications n'utilisant pas AutoCommit doivent appeler explicitement commit ou rollback avant d'appeler disconnect.

Utilisation de valeurs NULL

Des valeurs non définies, ou undef, sont utilisées pour indiquer des valeurs NULL. Vous pouvez insérer et mettre à jour des colonnes avec une valeur NULL comme vous le feriez avec une valeur non NULL. Ces exemples insèrent et mettent à jour l'âge de la colonne avec une valeur NULL -

$sth = $dbh->prepare(qq { INSERT INTO TEST_TABLE (FIRST_NAME, AGE) VALUES (?, ?) }); $sth->execute("Joe", undef);

Ici qq{} est utilisé pour renvoyer une chaîne entre guillemets à prepareAPI. Cependant, vous devez faire attention lorsque vous essayez d'utiliser des valeurs NULL dans une clause WHERE. Considérez -

SELECT FIRST_NAME FROM TEST_TABLE WHERE age = ?

Lier un undef (NULL) à l'espace réservé ne sélectionnera pas les lignes, qui ont un âge NULL! Au moins pour les moteurs de base de données conformes à la norme SQL. Reportez-vous au manuel SQL de votre moteur de base de données ou à tout livre SQL pour les raisons. Pour sélectionner explicitement NULL, vous devez dire "WHERE age IS NULL".

Un problème courant est qu'un fragment de code gère une valeur qui peut être définie ou non (non NULL ou NULL) au moment de l'exécution. Une technique simple consiste à préparer l'instruction appropriée selon les besoins et à remplacer l'espace réservé pour les cas non 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 : ());

Quelques autres fonctions DBI

available_drivers

@ary = DBI->available_drivers;
@ary = DBI->available_drivers($quiet);

Renvoie une liste de tous les pilotes disponibles en recherchant les modules DBD :: * dans les répertoires de @INC. Par défaut, un avertissement est donné si certains pilotes sont masqués par d'autres du même nom dans les répertoires précédents. Passer une valeur vraie pour $ quiet inhibera l'avertissement.

Installé_drivers

%drivers = DBI->installed_drivers();

Renvoie une liste de paires de noms de pilotes et de descripteurs de pilotes pour tous les pilotes «installés» (chargés) dans le processus en cours. Le nom du pilote n'inclut pas le préfixe «DBD ::».

les sources de données

@ary = DBI->data_sources($driver);

Renvoie une liste de sources de données (bases de données) disponibles via le pilote nommé. Si $ driver est vide ou undef, la valeur de la variable d'environnement DBI_DRIVER est utilisée.

citation

$sql = $dbh->quote($value); $sql = $dbh->quote($value, $data_type);

Citez un littéral de chaîne à utiliser comme valeur littérale dans une instruction SQL, en échappant tous les caractères spéciaux (tels que les guillemets) contenus dans la chaîne et en ajoutant le type requis de guillemets extérieurs.

$sql = sprintf "SELECT foo FROM bar WHERE baz = %s",
                $dbh->quote("Don't");

Pour la plupart des types de base de données, quote renverrait «Don» (y compris les guillemets extérieurs). La méthode quote () peut renvoyer une expression SQL qui correspond à la chaîne souhaitée. Par exemple -

$quoted = $dbh->quote("one\ntwo\0three")

may produce results which will be equivalent to

CONCAT('one', CHAR(12), 'two', CHAR(0), 'three')

Méthodes communes à toutes les poignées

se tromper

$rv = $h->err; or $rv = $DBI::err or $rv = $h->err

Renvoie le code d'erreur du moteur de base de données natif de la dernière méthode de pilote appelée. Le code est généralement un entier, mais vous ne devez pas le supposer. Ceci est équivalent à $ DBI :: err ou $ h-> err.

errstr

$str = $h->errstr; or $str = $DBI::errstr or $str = $h->errstr

Renvoie le message d'erreur du moteur de base de données natif de la dernière méthode DBI appelée. Cela pose les mêmes problèmes de durée de vie que la méthode "err" décrite ci-dessus. Ceci est équivalent à $ DBI :: errstr ou $ h-> errstr.

Lignes

$rv = $h->rows; or $rv = $DBI::rows

Cela renvoie le nombre de lignes effectuées par l'instruction SQL précédente et équivalent à $ DBI :: rows.

trace

$h->trace($trace_settings);

DBI possède une capacité extrêmement utile pour générer des informations de traçage d'exécution de ce qu'il fait, ce qui peut être un gain de temps énorme lorsque vous essayez de localiser des problèmes étranges dans vos programmes DBI. Vous pouvez utiliser différentes valeurs pour définir le niveau de trace. Ces valeurs varient de 0 à 4. La valeur 0 signifie désactiver la trace et 4 signifie générer une trace complète.

Les déclarations interpolées sont interdites

Il est fortement recommandé de ne pas utiliser d'instructions interpolées comme suit -

while ($first_name = <>) { my $sth = $dbh->prepare("SELECT * FROM TEST_TABLE WHERE FIRST_NAME = '$first_name'");
   $sth->execute();
   # and so on ...
}

Ainsi, n'utilisez pas l'instruction interpolée à la place, utilisez bind value pour préparer une instruction SQL dynamique.

Qu'est-ce que CGI?

  • Une interface de passerelle commune, ou CGI, est un ensemble de normes qui définit la manière dont les informations sont échangées entre le serveur Web et un script personnalisé.

  • Les spécifications CGI sont actuellement maintenues par le NCSA et NCSA définit CGI comme suit -

  • L'interface de passerelle commune, ou CGI, est une norme permettant aux programmes de passerelle externes de s'interfacer avec des serveurs d'informations tels que des serveurs HTTP.

  • La version actuelle est CGI / 1.1 et CGI / 1.2 est en cours de développement.

Navigation sur le Web

Pour comprendre le concept de CGI, voyons ce qui se passe lorsque nous cliquons sur un hyperlien disponible sur une page Web pour parcourir une page Web ou une URL particulière.

  • Votre navigateur contacte le serveur Web à l'aide du protocole HTTP et demande l'URL, c'est-à-dire le nom de fichier de la page Web.

  • Web Server vérifiera l'URL et recherchera le nom de fichier demandé. Si le serveur Web trouve ce fichier, il renvoie le fichier au navigateur sans autre exécution, sinon envoie un message d'erreur indiquant que vous avez demandé un mauvais fichier.

  • Le navigateur Web prend la réponse du serveur Web et affiche le contenu du fichier reçu ou un message d'erreur si le fichier est introuvable.

Cependant, il est possible de configurer le serveur HTTP de telle sorte que chaque fois qu'un fichier dans un certain répertoire est demandé, ce fichier ne soit pas renvoyé; au lieu de cela, il est exécuté en tant que programme, et quel que soit le résultat de ce programme, il est renvoyé pour que votre navigateur s'affiche. Cela peut être fait en utilisant une fonctionnalité spéciale disponible sur le serveur Web et elle est appeléeCommon Gateway Interfaceou CGI et de tels programmes qui sont exécutés par le serveur pour produire le résultat final, sont appelés scripts CGI. Ces programmes CGI peuvent être un script PERL, un script Shell, un programme C ou C ++, etc.

Diagramme d'architecture CGI

Prise en charge et configuration du serveur Web

Avant de poursuivre la programmation CGI, assurez-vous que votre serveur Web prend en charge la fonctionnalité CGI et qu'il est configuré pour gérer les programmes CGI. Tous les programmes CGI à exécuter par le serveur Web sont conservés dans un répertoire préconfiguré. Ce répertoire est appelé répertoire CGI et par convention, il est nommé comme / cgi-bin. Par convention, les fichiers Perl CGI auront une extension comme.cgi.

Premier programme CGI

Voici un lien simple qui est lié à un script CGI appelé hello.cgi . Ce fichier a été conservé dans/cgi-bin/répertoire et il a le contenu suivant. Avant d'exécuter votre programme CGI, assurez-vous que vous avez changé le mode de fichier en utilisantchmod 755 hello.cgi Commande 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;

Maintenant si vous cliquez hello.cgi lien puis demande va au serveur Web qui recherche hello.cgi dans le répertoire / cgi-bin, l'exécute et quel que soit le résultat généré, le serveur Web renvoie ce résultat au navigateur Web, comme suit -

Hello Word! This is my first CGI program

Ce script hello.cgi est un simple script Perl qui écrit sa sortie sur un fichier STDOUT, c'est-à-dire un écran. Il y a une caractéristique importante et supplémentaire disponible qui est la première ligne à imprimerContent-type:text/html\r\n\r\n. Cette ligne est renvoyée au navigateur et spécifie le type de contenu à afficher sur l'écran du navigateur. Vous devez maintenant avoir compris le concept de base de CGI et vous pouvez écrire de nombreux programmes CGI compliqués en utilisant Perl. Ce script peut interagir avec tout autre système d’exercice également pour échanger des informations telles qu’une base de données, des services Web ou toute autre interface complexe.

Comprendre l'en-tête HTTP

La toute première ligne Content-type:text/html\r\n\r\nfait partie de l'en-tête HTTP, qui est envoyé au navigateur afin que le navigateur puisse comprendre le contenu entrant du côté serveur. Tout l'en-tête HTTP sera sous la forme suivante -

HTTP Field Name: Field Content

Par exemple -

Content-type:text/html\r\n\r\n

Il existe quelques autres en-têtes HTTP importants que vous utiliserez fréquemment dans votre programmation CGI.

Sr.No. En-tête et description
1

Content-type: String

Une chaîne MIME définissant le format du contenu renvoyé. L'exemple est Content-type: text / html

2

Expires: Date String

La date à laquelle les informations deviennent invalides. Cela doit être utilisé par le navigateur pour décider quand une page doit être actualisée. Une chaîne de date valide doit être au format 01 janvier 1998 12:00:00 GMT.

3

Location: URL String

L'URL qui doit être renvoyée à la place de l'URL demandée. Vous pouvez utiliser ce fichier pour rediriger une demande vers n'importe quel autre emplacement.

4

Last-modified: String

La date de la dernière modification du fichier.

5

Content-length: String

La longueur, en octets, des données renvoyées. Le navigateur utilise cette valeur pour rapporter le temps de téléchargement estimé d'un fichier.

6

Set-Cookie: String

Définir le cookie passé à travers la chaîne

Variables d'environnement CGI

Tout le programme CGI aura accès aux variables d'environnement suivantes. Ces variables jouent un rôle important lors de l'écriture de tout programme CGI.

Sr.No. Noms et description des variables
1

CONTENT_TYPE

Le type de données du contenu. Utilisé lorsque le client envoie du contenu joint au serveur. Par exemple, téléchargement de fichiers, etc.

2

CONTENT_LENGTH

La longueur des informations de requête. Il est disponible uniquement pour les demandes POST

3

HTTP_COOKIE

Renvoie les cookies définis sous la forme d'une paire clé / valeur.

4

HTTP_USER_AGENT

Le champ d'en-tête de demande User-Agent contient des informations sur l'agent utilisateur à l'origine de la demande. Son nom du navigateur Web.

5

PATH_INFO

Le chemin du script CGI.

6

QUERY_STRING

The URL-encoded information that is sent with GET method request.

7

REMOTE_ADDR

The IP address of the remote host making the request. This can be useful for logging or for authentication purpose.

8

REMOTE_HOST

The fully qualified name of the host making the request. If this information is not available then REMOTE_ADDR can be used to get IR address.

9

REQUEST_METHOD

The method used to make the request. The most common methods are GET and POST.

10

SCRIPT_FILENAME

The full path to the CGI script.

11

SCRIPT_NAME

The name of the CGI script.

12

SERVER_NAME

The server's hostname or IP Address.

13

SERVER_SOFTWARE

The name and version of the software the server is running.

Here is a small CGI program to list down all the CGI variables supported by your Web server. Click this link to see the result Get Environment

#!/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;

Raise a "File Download" Dialog Box?

Sometime it is desired that you want to give option where a user will click a link and it will pop up a "File Download" dialogue box to the user instead of displaying actual content. This is very easy and will be achived through HTTP header.

This HTTP header will be different from the header mentioned in previous section. For example, if you want to make a FileName file downloadable from a given link then it's syntax will be as follows −

#!/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");
}

GET and POST Methods

You must have come across many situations when you need to pass some information from your browser to the web server and ultimately to your CGI Program handling your requests. Most frequently browser uses two methods to pass this information to the web server. These methods are GET Method and POST Method. Let's check them one by one.

Passing Information using GET Method

The GET method sends the encoded user information appended to the page URL itself. The page and the encoded information are separated by the ? character as follows −

http://www.test.com/cgi-bin/hello.cgi?key1=value1&key2=value2

The GET method is the defualt method to pass information from a browser to the web server and it produces a long string that appears in your browser's Location:box. You should never use GET method if you have password or other sensitive information to pass to the server. The GET method has size limitation: only 1024 characters can be passed in a request string.

This information is passed using QUERY_STRING header and will be accessible in your CGI Program through QUERY_STRING environment variable which you can parse and use in your CGI program.

You can pass information by simply concatenating key and value pairs alongwith any URL or you can use HTML <FORM> tags to pass information using GET method.

Simple URL Example: Get Method

Here is a simple URL which will pass two values to hello_get.cgi program using GET method.

http://www.tutorialspoint.com/cgi-bin/hello_get.cgi?first_name=ZARA&last_name=ALI

Below is hello_get.cgi script to handle input given by web browser.

#!/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;

Simple FORM Example: GET Method

Here is a simple example, which passes two values using HTML FORM and submit button. We are going to use the same CGI script hello_get.cgi to handle this input.

<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>

Here is the actual output of the above form coding. Now you can enter First and Last Name and then click submit button to see the result.

Passing Information using POST Method

A more reliable method of passing information to a CGI program is the POST method. This packages the information in exactly the same way as GET methods, but instead of sending it as a text string after a ? in the URL, it sends it as a separate message as a part of HTTP header. Web server provides this message to the CGI script in the form of the standard input.

Below is the modified hello_post.cgi script to handle input given by the web browser. This script will handle GET as well as POST method.

#!/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;

Let us take again same examle as above, which passes two values using HTML FORM and submit button. We are going to use CGI script hello_post.cgi to handle this input.

<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>

Here is the actual output of the above form coding, You enter First and Last Name and then click submit button to see the result.

Passing Checkbox Data to CGI Program

Checkboxes are used when more than one option is required to be selected. Here is an example HTML code for a form with two checkboxes.

<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>

The result of this code is the following form −

Below is checkbox.cgi script to handle input given by web browser for radio button.

#!/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;

Passing Radio Button Data to CGI Program

Radio Buttons are used when only one option is required to be selected. Here is an example HTML code for a form with two radio button −

<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>

The result of this code is the following form −

Below is radiobutton.cgi script to handle input given by the web browser for radio button.

#!/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;

Passing Text Area Data to CGI Program

A textarea element is used when multiline text has to be passed to the CGI Program. Here is an example HTML code for a form with a TEXTAREA box −

<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>

The result of this code is the following form −

Below is the textarea.cgi script to handle input given by the web browser.

#!/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;

Passing Drop Down Box Data to CGI Program

A drop down box is used when we have many options available but only one or two will be selected. Here is example HTML code for a form with one drop down box

<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>

The result of this code is the following form −

Below is the dropdown.cgi script to handle input given by web browser.

#!/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;

Utilisation de cookies dans CGI

Le protocole HTTP est un protocole sans état. Mais pour un site Web commercial, il est nécessaire de conserver les informations de session entre différentes pages. Par exemple, l'enregistrement d'un utilisateur se termine après des transactions qui s'étendent sur plusieurs pages. Mais comment conserver les informations de session de l'utilisateur sur toutes les pages Web?

Dans de nombreuses situations, l'utilisation de cookies est la méthode la plus efficace pour mémoriser et suivre les préférences, les achats, les commissions et d'autres informations nécessaires pour une meilleure expérience des visiteurs ou des statistiques du site.

Comment ça fonctionne

Votre serveur envoie certaines données au navigateur du visiteur sous la forme d'un cookie. Le navigateur peut accepter le cookie. Si tel est le cas, il est stocké sous forme d'enregistrement en texte brut sur le disque dur du visiteur. Désormais, lorsque le visiteur arrive sur une autre page de votre site, le cookie est disponible pour la récupération. Une fois récupéré, votre serveur sait / se souvient de ce qui a été stocké.

Les cookies sont un enregistrement de données en texte brut de 5 champs de longueur variable -

  • Expires- La date d'expiration du cookie. Si ce champ est vide, le cookie expirera lorsque le visiteur quittera le navigateur.

  • Domain - Le nom de domaine de votre site.

  • Path- Le chemin d'accès au répertoire ou à la page Web qui a défini le cookie. Cela peut être vide si vous souhaitez récupérer le cookie à partir de n'importe quel répertoire ou page.

  • Secure- Si ce champ contient le mot «sécurisé», alors le cookie ne peut être récupéré qu'avec un serveur sécurisé. Si ce champ est vide, une telle restriction n'existe pas.

  • Name = Value - Les cookies sont définis et revus sous la forme de paires clé et valeur.

Configurer les cookies

Il est très facile d'envoyer des cookies au navigateur. Ces cookies seront envoyés avec l'en-tête HTTP. En supposant que vous souhaitiez définir l'ID utilisateur et le mot de passe en tant que cookies. Donc, ce sera fait comme suit -

#!/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....

Ici nous avons utilisé Set-CookieEn-tête HTTP pour définir les cookies. Il est facultatif de définir des attributs de cookies tels que Expire, Domain et Path. Il est important de noter que les cookies sont définis avant l'envoi de la ligne magique"Content-type:text/html\r\n\r\n.

Récupération des cookies

Il est très facile de récupérer tous les cookies définis. Les cookies sont stockés dans la variable d'environnement CGI HTTP_COOKIE et ils auront la forme suivante.

key1 = value1;key2 = value2;key3 = value3....

Voici un exemple de récupération des cookies.

#!/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";

Cela produira le résultat suivant, à condition que les cookies ci-dessus aient été définis avant d'appeler le script de cookies de récupération.

User ID = XYZ
Password = XYZ123

Modules et bibliothèques CGI

Vous trouverez de nombreux modules intégrés sur Internet qui vous fournissent des fonctions directes à utiliser dans votre programme CGI. Voici les moments importants.

  • Module CGI

  • Berkeley cgi-lib.pl

Que sont les packages?

le packageL'instruction bascule le contexte de dénomination actuel vers un espace de noms spécifié (table de symboles). Ainsi -

  • Un package est une collection de code qui vit dans son propre espace de noms.

  • Un espace de noms est une collection nommée de noms de variables uniques (également appelée table de symboles).

  • Les espaces de noms empêchent les collisions de noms de variables entre les packages.

  • Les packages permettent la construction de modules qui, lorsqu'ils sont utilisés, ne suppriment pas les variables et les fonctions en dehors du propre espace de noms des modules.

  • Le package reste en vigueur jusqu'à ce qu'une autre instruction package soit appelée, ou jusqu'à la fin du bloc ou du fichier en cours.

  • Vous pouvez explicitement faire référence à des variables dans un package en utilisant le :: qualificatif de package.

Voici un exemple de packages main et Foo dans un fichier. Ici, la variable spéciale __PACKAGE__ a été utilisée pour imprimer le nom du package.

#!/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;

Lorsque le code ci-dessus est exécuté, il produit le résultat suivant -

Package name : main 1
Package name : Foo 10
Package name : main 100
Package name : main 10

Blocs BEGIN et END

Vous pouvez définir n'importe quel nombre de blocs de code nommés BEGIN et END, qui agissent respectivement comme des constructeurs et des destructeurs.

BEGIN { ... }
END { ... }
BEGIN { ... }
END { ... }
  • Chaque BEGIN block est exécuté après le chargement et la compilation du script perl, mais avant l'exécution de toute autre instruction.

  • Chaque bloc END est exécuté juste avant la fermeture de l'interpréteur perl.

  • Les blocs BEGIN et END sont particulièrement utiles lors de la création de modules Perl.

L'exemple suivant montre son utilisation -

#!/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;

Lorsque le code ci-dessus est exécuté, il produit le résultat suivant -

This is BEGIN Block
Begin and Block Demo
This is END Block

Que sont les modules Perl?

Un module Perl est un package réutilisable défini dans un fichier bibliothèque dont le nom est le même que le nom du package avec l'extension .pm.

Un fichier de module Perl appelé Foo.pm peut contenir des déclarations comme celle-ci.

#!/usr/bin/perl

package Foo;
sub bar { 
   print "Hello $_[0]\n" 
}

sub blat { 
   print "World $_[0]\n" 
}
1;

Quelques points importants sur les modules Perl

  • Les fonctions require et use chargera un module.

  • Les deux utilisent la liste des chemins de recherche dans @INC pour trouver le module.

  • Les deux fonctions require et use appeler le eval fonction pour traiter le code.

  • le 1; en bas, eval s'évalue à TRUE (et donc n'échoue pas).

La fonction Require

Un module peut être chargé en appelant le require fonction comme suit -

#!/usr/bin/perl

require Foo;

Foo::bar( "a" );
Foo::blat( "b" );

Vous devez avoir remarqué que les noms de sous-programmes doivent être pleinement qualifiés pour les appeler. Ce serait bien d'activer le sous-programmebar et blat à importer dans notre propre espace de noms pour ne pas avoir à utiliser le qualificatif Foo ::.

La fonction d'utilisation

Un module peut être chargé en appelant le use fonction.

#!/usr/bin/perl

use Foo;

bar( "a" );
blat( "b" );

Notez que nous n'avons pas eu à qualifier complètement les noms de fonctions du package. leuse function exportera une liste de symboles d'un module à partir de quelques instructions ajoutées à l'intérieur d'un module.

require Exporter;
@ISA = qw(Exporter);

Ensuite, fournissez une liste de symboles (scalaires, listes, hachages, sous-programmes, etc.) en remplissant la variable de liste nommée @EXPORT: Par exemple -

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;

Créer l'arborescence des modules Perl

Lorsque vous êtes prêt à expédier votre module Perl, il existe un moyen standard de créer une arborescence de modules Perl. Ceci est fait en utilisanth2xsutilitaire. Cet utilitaire est fourni avec Perl. Voici la syntaxe pour utiliser h2xs -

$h2xs -AX -n  ModuleName

Par exemple, si votre module est disponible dans Person.pm fichier, puis exécutez simplement la commande suivante -

$h2xs -AX -n Person

Cela produira le résultat suivant -

Writing Person/lib/Person.pm
Writing Person/Makefile.PL
Writing Person/README
Writing Person/t/Person.t
Writing Person/Changes
Writing Person/MANIFEST

Voici la description de ces options -

  • -A omet le code de l'Autoloader (mieux utilisé par les modules qui définissent un grand nombre de sous-programmes rarement utilisés).

  • -X omet les éléments XS (eXternal Subroutine, où eXternal signifie externe à Perl, c'est-à-dire C).

  • -n spécifie le nom du module.

La commande ci-dessus crée la structure suivante dans le répertoire Person. Le résultat réel est indiqué ci-dessus.

  • Changes
  • Makefile.PL
  • MANIFEST (contient la liste de tous les fichiers du package)
  • README
  • t / (fichiers de test)
  • lib / (le code source réel va ici

Alors finalement, toi tarcette structure de répertoire dans un fichier Person.tar.gz et vous pouvez l'envoyer. Vous devrez mettre à jour le fichier README avec les instructions appropriées. Vous pouvez également fournir des fichiers d'exemples de test dans le répertoire t.

Installer le module Perl

Téléchargez un module Perl sous la forme de fichier tar.gz. Utilisez la séquence suivante pour installer n'importe quel module PerlPerson.pm qui a été téléchargé en tant que Person.tar.gz fichier.

tar xvfz Person.tar.gz
cd Person
perl Makefile.PL
make
make install

L'interpréteur Perl a une liste de répertoires dans lesquels il recherche des modules (tableau global @INC).

Vous pouvez utiliser Perl de différentes manières pour créer de nouveaux processus selon vos besoins. Ce tutoriel répertorie quelques méthodes importantes et les plus fréquemment utilisées pour créer et gérer des processus Perl.

  • Vous pouvez utiliser des variables spéciales $$ ou $PROCESS_ID pour obtenir l'ID de processus actuel.

  • Chaque processus créé en utilisant l'une des méthodes mentionnées, maintient son propre environnement virtuel avec-in %ENV variable.

  • le exit() La fonction quitte toujours uniquement le processus enfant qui exécute cette fonction et le processus principal dans son ensemble ne se terminera que si tous les processus enfants en cours d'exécution sont sortis.

  • Toutes les poignées ouvertes sont dup () - éditées dans les processus enfants, de sorte que la fermeture de toutes les poignées dans un processus n'affecte pas les autres.

Opérateur Backstick

Cette manière la plus simple d'exécuter toute commande Unix consiste à utiliser l'opérateur backstick. Vous mettez simplement votre commande à l'intérieur de l'opérateur backstick, ce qui entraînera l'exécution de la commande et retournera son résultat qui peut être stocké comme suit -

#!/usr/bin/perl

@files = `ls -l`;

foreach $file (@files) { print $file;
}

1;

Lorsque le code ci-dessus est exécuté, il répertorie tous les fichiers et répertoires disponibles dans le répertoire courant -

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

La fonction system ()

Vous pouvez aussi utiliser system()pour exécuter toute commande Unix, dont la sortie ira à la sortie du script perl. Par défaut, c'est l'écran, c'est-à-dire STDOUT, mais vous pouvez le rediriger vers n'importe quel fichier en utilisant l'opérateur de redirection> -

#!/usr/bin/perl

system( "ls -l")

1;

Lorsque le code ci-dessus est exécuté, il répertorie tous les fichiers et répertoires disponibles dans le répertoire courant -

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

Soyez prudent lorsque votre commande contient des variables d'environnement shell comme $PATH or $DOMICILE. Essayez de suivre trois scénarios -

#!/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;

Lorsque le code ci-dessus est exécuté, il produit le résultat suivant en fonction de ce qui est défini dans la variable shell $ 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

La fonction fork ()

Perl fournit un fork()fonction qui correspond à l'appel système Unix du même nom. Sur la plupart des plates-formes de type Unix où l'appel système fork () est disponible, fork () de Perl l'appelle simplement. Sur certaines plates-formes telles que Windows où l'appel système fork () n'est pas disponible, Perl peut être construit pour émuler fork () au niveau de l'interpréteur.

La fonction fork () est utilisée pour cloner un processus en cours. Cet appel crée un nouveau processus exécutant le même programme au même point. Il renvoie le pid enfant au processus parent, 0 au processus enfant ou undef si le fork échoue.

Vous pouvez utiliser exec() dans un processus pour lancer l'exécutable demandé, qui sera exécuté dans une zone de processus séparée et exec () attendra qu'il se termine avant de quitter avec le même statut de sortie que ce processus.

#!/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;

Lorsque le code ci-dessus est exécuté, il produit le résultat suivant -

Printed by parent process
Printed by child process
Tue Sep 17 15:41:08 CDT 2013
Completed process id: 17777

le wait() et waitpid()peut être passé en tant qu'ID de pseudo-processus renvoyé par fork (). Ces appels attendront correctement la fin du pseudo-processus et renverront son état. Si vous bifurquez sans jamais attendre que vos enfants utilisentwaitpid()fonction, vous accumulerez des zombies. Sur les systèmes Unix, vous pouvez éviter cela en définissant $ SIG {CHLD} sur "IGNORE" comme suit -

#!/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;

Lorsque le code ci-dessus est exécuté, il produit le résultat suivant -

Printed by parent process
Printed by child process
Tue Sep 17 15:44:07 CDT 2013
Completed process id: -1

La fonction kill ()

Perl kill('KILL', (Process List)) peut être utilisée pour terminer un pseudo-processus en lui passant l'ID retourné par fork ().

Notez que l'utilisation de kill ('KILL', (Process List)) sur un pseudo-processus () peut généralement provoquer des fuites de mémoire, car le thread qui implémente le pseudo-processus n'a pas la possibilité de nettoyer ses ressources.

Vous pouvez utiliser kill() fonction pour envoyer tout autre signal aux processus cibles, par exemple suivant enverra SIGINT à un processus ID 104 et 102 -

#!/usr/bin/perl

kill('INT', 104, 102);
 
1;

Vous pouvez intégrer la documentation Pod (Plain Old Text) dans vos modules et scripts Perl. Voici la règle pour utiliser la documentation intégrée dans votre code Perl -

Commencez votre documentation avec une ligne vide, a =head1 commande au début et terminez-la par un =cut

Perl ignorera le texte du pod que vous avez entré dans le code. Voici un exemple simple d'utilisation de la documentation intégrée dans votre code Perl -

#!/usr/bin/perl

print "Hello, World\n";

=head1 Hello, World Example
This example demonstrate very basic syntax of Perl.
=cut

print "Hello, Universe\n";

Lorsque le code ci-dessus est exécuté, il produit le résultat suivant -

Hello, World
Hello, Universe

Si vous allez mettre votre Pod à la fin du fichier et que vous utilisez une marque de coupe __END__ ou __DATA__, assurez-vous de mettre une ligne vide avant la première commande de Pod comme suit, sinon sans ligne vide avant le =head1, de nombreux traducteurs n'auraient pas reconnu le =head1 comme démarrage d'un bloc 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";

Lorsque le code ci-dessus est exécuté, il produit le résultat suivant -

Hello, World

=head1 Hello, World Example
This example demonstrate very basic syntax of Perl.
print "Hello, Universe\n";

Prenons un autre exemple pour le même code sans lire la partie DATA -

#!/usr/bin/perl

print "Hello, World\n";

__END__

=head1 Hello, World Example
This example demonstrate very basic syntax of Perl.
print "Hello, Universe\n";

Lorsque le code ci-dessus est exécuté, il produit le résultat suivant -

Hello, World

Qu'est-ce que le POD?

Pod est un langage de balisage simple à utiliser utilisé pour écrire de la documentation pour Perl, les programmes Perl et les modules Perl. Il existe différents traducteurs disponibles pour convertir Pod en différents formats tels que le texte brut, le HTML, les pages de manuel, etc. Le balisage de pod se compose de trois types de paragraphes de base -

  • Ordinary Paragraph - Vous pouvez utiliser des codes de mise en forme dans des paragraphes ordinaires, pour le gras, l'italique, le style de code, les hyperliens, etc.

  • Verbatim Paragraph - Les paragraphes verbatim sont généralement utilisés pour présenter un bloc de code ou un autre texte qui ne nécessite aucune analyse ou mise en forme particulière, et qui ne doit pas être enveloppé.

  • Command Paragraph- Un paragraphe de commande est utilisé pour le traitement spécial de morceaux entiers de texte, généralement en tant que titres ou parties de listes. Tous les paragraphes de commande commencent par =, suivi d'un identifiant, suivi d'un texte arbitraire que la commande peut utiliser comme bon lui semble. Les commandes actuellement reconnues sont -

=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

Exemples de POD

Considérez le POD suivant -

=head1 SYNOPSIS
Copyright 2005 [TUTORIALSOPOINT].
=cut

Vous pouvez utiliser pod2html utilitaire disponible sur Linux pour convertir ci-dessus POD en HTML, donc il produira le résultat suivant -

Ensuite, considérons l'exemple suivant -

=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

Lorsque vous convertissez le POD ci-dessus en HTML à l'aide de pod2html, il produira le résultat suivant -

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.

Voici la liste de toutes les fonctions importantes supportées par Perl standard.

  • abs - fonction de valeur absolue

  • accepter - accepter une connexion de prise entrante

  • alarme - programmer un SIGALRM

  • atan2 - arc tangente de Y / X dans la plage -PI à PI

  • bind - lie une adresse à une socket

  • binmode - prépare les fichiers binaires pour les E / S

  • bénir - créer un objet

  • caller - récupère le contexte de l'appel de sous-programme actuel

  • chdir - changez votre répertoire de travail actuel

  • chmod - change les permissions sur une liste de fichiers

  • chomp - supprime un séparateur d'enregistrement de fin d'une chaîne

  • chop - supprime le dernier caractère d'une chaîne

  • chown - changer la propriété sur une liste de fichiers

  • chr - obtenir le caractère que ce nombre représente

  • chroot - créer une nouvelle racine du répertoire pour les recherches de chemin

  • close - ferme le descripteur de fichier (ou de tuyau ou de socket)

  • closedir - fermer le descripteur du répertoire

  • connecter - se connecter à une prise distante

  • continue - bloc de fin facultatif dans un moment ou foreach

  • cos - fonction cosinus

  • crypt - cryptage à sens unique de type passwd

  • dbmclose - interrompt la liaison sur un fichier dbm lié

  • dbmopen - crée une liaison sur un fichier dbm lié

  • défini - teste si une valeur, une variable ou une fonction est définie ou non

  • delete - supprime une valeur d'un hachage

  • mourir - lever une exception ou renflouer

  • faire - transformer un BLOC en TERME

  • dump - créer un vidage de mémoire immédiat

  • each - récupère la prochaine paire clé / valeur à partir d'un hachage

  • endgrent - être fait en utilisant le fichier de groupe

  • endhostent - être fait en utilisant le fichier hosts

  • endnetent - être fait en utilisant le fichier de réseaux

  • endprotoent - être fait en utilisant le fichier de protocoles

  • endpwent - être fait en utilisant le fichier passwd

  • endervent - être fait en utilisant le fichier de services

  • eof - teste un descripteur de fichier pour sa fin

  • eval - intercepter les exceptions ou compiler et exécuter du code

  • exec - abandonne ce programme pour en lancer un autre

  • existe - teste si une clé de hachage est présente

  • exit - termine ce programme

  • exp - élever je à une puissance

  • fcntl - appel système de contrôle de fichiers

  • fileno - renvoie le descripteur de fichier depuis le descripteur de fichier

  • flock - verrouille un fichier entier avec un verrou consultatif

  • fork - créez un nouveau processus comme celui-ci

  • format - déclare un format d'image à utiliser par la fonction write ()

  • formline - fonction interne utilisée pour les formats

  • getc - récupère le caractère suivant du descripteur de fichier

  • getgrent - obtenir le prochain enregistrement de groupe

  • getgrgid - obtenir un enregistrement de groupe avec l'ID utilisateur du groupe

  • getgrnam - obtenir un enregistrement de groupe avec le nom du groupe

  • gethostbyaddr - obtenir l'enregistrement d'hôte en fonction de son adresse

  • gethostbyname - récupère le nom de l'enregistrement d'hôte

  • gethostent - obtenir le prochain enregistrement des hôtes

  • getlogin - retourne qui s'est connecté à ce tty

  • getnetbyaddr - obtenir un enregistrement réseau en fonction de son adresse

  • getnetbyname - obtenir le nom donné de l'enregistrement des réseaux

  • getnetent - obtenir le prochain enregistrement de réseaux

  • getpeername - trouve l'autre extrémité d'une connexion socket

  • getpgrp - obtenir un groupe de processus

  • getppid - obtenir l'ID du processus parent

  • getpriority - obtenir la valeur actuelle de Nice

  • getprotobyname - obtenir le nom donné de l'enregistrement de protocole

  • getprotobynumber - obtenir le protocole numérique d'enregistrement de protocole

  • getprotoent - obtenir le prochain enregistrement de protocoles

  • getpwent - obtenir le prochain enregistrement passwd

  • getpwnam - récupère l'enregistrement passwd avec le nom de connexion de l'utilisateur

  • getpwuid - récupère l'enregistrement passwd avec l'ID utilisateur

  • getservbyname - récupère l'enregistrement des services en fonction de son nom

  • getservbyport - obtenir un enregistrement de services avec un port numérique

  • getservent - obtenir le prochain enregistrement de services

  • getsockname - récupère le sockaddr pour une socket donnée

  • getsockopt - récupère les options de socket sur une socket donnée

  • glob - développez les noms de fichiers à l'aide de caractères génériques

  • gmtime - convertit l'heure UNIX en enregistrement ou en chaîne en utilisant le format d'heure de Greenwich.

  • goto - créer du code spaghetti

  • grep - localise les éléments dans une liste teste vrai par rapport à un critère donné

  • hex - convertit une chaîne en un nombre hexadécimal

  • import - patch de l'espace de noms d'un module dans le vôtre

  • index - trouve une sous-chaîne dans une chaîne

  • int - récupère la partie entière d'un nombre

  • ioctl - appel système de contrôle de périphérique dépendant du système

  • join - joindre une liste dans une chaîne en utilisant un séparateur

  • keys - récupère la liste des index à partir d'un hachage

  • kill - envoyer un signal à un processus ou à un groupe de processus

  • dernier - quitter un bloc prématurément

  • lc - retourne la version minuscule d'une chaîne

  • lcfirst - renvoie une chaîne avec juste la lettre suivante en minuscule

  • length - renvoie le nombre d'octets dans une chaîne

  • link - créer un lien dur dans le système de fichiers

  • Listen - enregistrez votre socket en tant que serveur

  • local - crée une valeur temporaire pour une variable globale (portée dynamique)

  • localtime - convertit l'heure UNIX en enregistrement ou en chaîne en utilisant l'heure locale

  • lock - obtenir un verrou de thread sur une variable, un sous-programme ou une méthode

  • log - récupère le logarithme naturel d'un nombre

  • lstat - stat un lien symbolique

  • m - correspond à une chaîne avec un modèle d'expression régulière

  • map - appliquer une modification à une liste pour récupérer une nouvelle liste avec les modifications

  • mkdir - crée un répertoire

  • msgctl - Opérations de contrôle des messages SysV IPC

  • msgget - obtenir la file d'attente de messages SysV IPC

  • msgrcv - reçoit un message SysV IPC à partir d'une file d'attente de messages

  • msgsnd - envoyer un message SysV IPC à une file d'attente de messages

  • my - déclarer et affecter une variable locale (portée lexicale)

  • suivant - itérer un bloc prématurément

  • no - sans importer certains symboles de module ou sémantiques au moment de la compilation

  • oct - convertit une chaîne en un nombre octal

  • open - ouvre un fichier, un tube ou un descripteur

  • opendir - ouvre un répertoire

  • ord - recherche la représentation numérique d'un caractère

  • our - déclarer et affecter une variable de package (portée lexicale)

  • pack - convertit une liste en une représentation binaire

  • package - déclare un espace de noms global distinct

  • pipe - ouvre une paire de descripteurs de fichiers connectés

  • pop - supprime le dernier élément d'un tableau et le renvoie

  • pos - trouve ou définit le décalage pour la dernière / prochaine recherche m // g

  • print - affiche une liste dans un descripteur de fichier

  • printf - affiche une liste formatée dans un descripteur de fichier

  • prototype - obtenir le prototype (le cas échéant) d'un sous-programme

  • push - ajoute un ou plusieurs éléments à un tableau

  • q - cite une chaîne séparément

  • qq - entre deux guillemets une chaîne

  • qr - Modèle de compilation

  • quotemeta - cite des caractères magiques d'expression régulière

  • qw - citer une liste de mots

  • qx - backquote quote une chaîne

  • rand - récupère le prochain nombre pseudo-aléatoire

  • read - entrée mise en mémoire tampon de longueur fixe à partir d'un descripteur de fichier

  • readdir - récupère un répertoire à partir d'un descripteur de répertoire

  • readline - récupère un enregistrement à partir d'un fichier

  • readlink - déterminer où pointe un lien symbolique

  • readpipe - exécute une commande système et collecte la sortie standard

  • recv - recevoir un message sur un socket

  • refaire - recommencez cette itération de boucle

  • ref - découvrez le type de chose référencée

  • renommer - changer un nom de fichier

  • require - charger des fonctions externes à partir d'une bibliothèque au moment de l'exécution

  • reset - efface toutes les variables d'un nom donné

  • return - sortir tôt d'une fonction

  • reverse - retourne une chaîne ou une liste

  • rewinddir - réinitialiser le handle du répertoire

  • rindex - recherche de sous-chaînes de droite à gauche

  • rmdir - supprimer un répertoire

  • s - remplace un motif par une chaîne

  • scalaire - force un contexte scalaire

  • seek - repositionner le pointeur de fichier pour les E / S à accès aléatoire

  • seekdir - repositionner le pointeur du répertoire

  • sélectionner - réinitialiser la sortie par défaut ou effectuer le multiplexage E / S

  • semctl - Opérations de contrôle de sémaphore SysV

  • semget - obtenir un ensemble de sémaphores SysV

  • semop - Opérations de sémaphore SysV

  • envoyer - envoyer un message sur une socket

  • setgrent - prépare le fichier de groupe pour l'utilisation

  • sethostent - prépare le fichier d'hôtes à utiliser

  • setnetent - prépare le fichier de réseaux à utiliser

  • setpgrp - définit le groupe de processus d'un processus

  • setpriority - définit la valeur intéressante d'un processus

  • setprotoent - prépare le fichier de protocoles à utiliser

  • setpwent - prépare le fichier passwd pour utilisation

  • setservent - prépare le fichier de services à utiliser

  • setsockopt - définir certaines options de socket

  • shift - supprime le premier élément d'un tableau et le renvoie

  • shmctl - Opérations de mémoire partagée SysV

  • shmget - récupère l'identifiant de segment de mémoire partagée SysV

  • shmread - lecture de la mémoire partagée SysV

  • shmwrite - écrire la mémoire partagée SysV

  • shutdown - ne ferme que la moitié d'une connexion socket

  • sin - renvoie le sinus d'un nombre

  • sleep - bloquer pendant un certain nombre de secondes

  • socket - créer une socket

  • socketpair - crée une paire de sockets

  • sort - trier une liste de valeurs

  • splice - ajouter ou supprimer des éléments n'importe où dans un tableau

  • split - divise une chaîne à l'aide d'un délimiteur d'expression régulière

  • sprintf - impression formatée en une chaîne

  • sqrt - fonction racine carrée

  • srand - amorce le générateur de nombres aléatoires

  • stat - obtenir les informations sur l'état d'un fichier

  • étude - optimiser les données d'entrée pour les recherches répétées

  • sub - déclarer un sous-programme, éventuellement de manière anonyme

  • substr - obtenir ou modifier une partie de l'agitation

  • lien symbolique - crée un lien symbolique vers un fichier

  • syscall - exécute un appel système arbitraire

  • sysopen - ouvre un fichier, un tube ou un descripteur

  • sysread - entrée non tamponnée de longueur fixe à partir d'un descripteur de fichier

  • sysseek - positionne le pointeur d'E / S sur le handle utilisé avec sysread et syswrite

  • système - exécuter un programme séparé

  • syswrite - sortie sans tampon de longueur fixe vers un descripteur de fichier

  • tell - obtenir le pointeur de recherche actuel sur un descripteur de fichier

  • telldir - récupère le pointeur de recherche actuel sur un descripteur de répertoire

  • tie - lier une variable à une classe d'objets

  • lié - obtenir une référence à l'objet sous-jacent à une variable liée

  • time - renvoie le nombre de secondes depuis 1970

  • times - renvoie le temps écoulé pour les processus auto et enfants

  • tr - translittération d'une chaîne

  • tronquer - raccourcir un fichier

  • uc - retourne la version majuscule d'une chaîne

  • ucfirst - renvoie une chaîne avec juste la lettre suivante en majuscules

  • umask - définir le masque de mode de création de fichier

  • undef - supprime une variable ou une définition de fonction

  • Dissocier - supprimer un lien vers un fichier

  • unpack - convertit la structure binaire en variables perl normales

  • unshift - ajouter plus d'éléments au début d'une liste

  • délier - briser une cravate liée à une variable

  • use - charge dans un module au moment de la compilation

  • utime - définir le dernier accès d'un fichier et modifier les heures

  • values - renvoie une liste des valeurs dans un hachage

  • vec - tester ou définir des bits particuliers dans une chaîne

  • attendez - attendez que tout processus fils meure

  • waitpid - attend qu'un processus fils particulier meure

  • wantarray - obtenir le contexte void vs scalar vs list de l'appel de sous-programme actuel

  • warn - affiche les informations de débogage

  • écrire - imprimer un enregistrement d'image

  • -X - un test de fichier (-r, -x, etc.)

  • y - translittération d'une chaîne