Différences entre versions de « Perl »
(2 versions intermédiaires par le même utilisateur non affichées) | |||
Ligne 381 : | Ligne 381 : | ||
#recupere le contenu du buffer de l'entrée standard STDIN | #recupere le contenu du buffer de l'entrée standard STDIN | ||
$in = <STDIN>; | $in = <STDIN>; | ||
− | #supprime les deux CRLF | + | #supprime les deux CRLF insérés par le protocole HTTP |
chop($in); | chop($in); | ||
chop($in); | chop($in); | ||
− | #dissocie la chaine de | + | #dissocie la chaine de caractère en une liste |
@liste = split(/&/,$in); | @liste = split(/&/,$in); | ||
#parcours de la liste | #parcours de la liste | ||
Ligne 396 : | Ligne 396 : | ||
#Traitement des donnees ... | #Traitement des donnees ... | ||
} | } | ||
+ | *'''Le formulaire''' | ||
+ | [[Fichier:Fo1.png|Fo1.png]] | ||
+ | |||
+ | |||
+ | *'''Le script Perl:''' | ||
+ | [[Fichier:Fo2.png|Fo2.png]] | ||
}}<!--************** Fin Fiche Didactique Explicitations ******************* --> | }}<!--************** Fin Fiche Didactique Explicitations ******************* --> | ||
Version actuelle datée du 23 mai 2021 à 22:21
Votre Publicité sur le Réseau |
Traduction
Traductions
Définition
Domaine, Discipline, Thématique
Justification
Définition écrite
- Perl (Practical Extraction and Report Language) ou (langage pratique d'extraction et de génération de rapports):
- Perl est un langage de programmation créé par Larry Wall en 1987 et reprenant des fonctionnalités du langage C et des langages de scripts sed, awk et shell (sh).
- C'est un langage interprété, polyvalent, et particulièrement adapté au traitement et à la manipulation de fichiers texte, notamment du fait de l'intégration des expressions régulières dans la syntaxe même du langage.
* Date de première version: 18 décembre 1987 .
* Paradigmes: Objet, impératif, fonctionnel, réflexif, procédural, événementiel, générique
* Auteur: Larry Wall
* Développeurs: The Perl Foundation
* Licence: Licence artistique 1.0[4][5] ou licence publique générale GNU[6] * Dernière version: 5.32.1 (23 janvier 2021) * Système d'exploitation: Multiplateforme
* Typage: Faible, dynamique
* Influencé par: C, BASIC, Eiffel, shell, sed, awk
* Écrit en: C
* Extensions de noms de fichiers: .plx, .pl, .pm, .xs, .t, .pod
* Site internet: www.perl.org
Il en existe plusieurs editeurs comme :* , *Notepad++......
Exemple use strict; use warnings; print "Hello, world!"; <>; La première ligne est un commentaire obligatoire qui indique l'endroit où les trouve l'interpréteur Perl. La deuxième ligne est une commande, qui imprimera Hello, world! à l'écran une fois exécuté le programme
Le mettre dans un fichier, par exemple helloworld.pl. Rendre le fichier exécutable (LINUX: chmod u+x helloworld.pl). Taper le nom du fichier helloworld.pl |
Perl - Historique (+)
Définition graphique
Concepts ou notions associés
Perl - Glossaire / (+)
Exemples, applications, utilisations
a) Les types de données Perl est un langage faiblement typé. Il existe principalement trois structures de données : les scalaires, les tableaux et les tables de hachage. * Chaque structure de données est liée à un caractère spécial. .1)Les variables scalaires Les variables scalaires peuvent contenir soit des nombres soit des chaînes de caractères. * *Exemple $priority = 9; $priority = "high"; $priority = 'high'; Les noms des variables ne commencent jamais par un nombre. Elles ont pour préfixe le caractère $. La variable $_ est spéciale. *Assignation Les opérateurs arithmétiques fonctionnent comme en C. *Exemple $a = 1 + 2; $a++; *Les opérateurs sur les Strings sont les suivants: *Exemple $a = $b . $c; # Concaténation de $b et $c $a = $b x $c; # $b est répété $c fois $a .= $b; # On ajoute (append) $b à $a (String) *Affichage des variables *Exemple Le code suivant affiche "pommes et poires" : $a = "pommes"; $b = "poires"; print "$a et $b\n"; Le code suivant affiche "4 pommes" : $a = "pommes"; $b = 4; print "$b $a\n"; .2)Les variables de type tableau *Les tableaux sont des listes de scalaires (nombres ou chaînes de caractères). Les variables de tableaux ont le même format que les variables scalaires à part qu'elles sont préfixées par le symbole @. *Exemple @food = ("apples", "pears", "eels"); @music = ("whistle", "flute"); On assigne une liste de trois éléments dans une variable de tableau @food et une liste de deux éléments à une variable de tableau @music. *On peut accéder aux différents éléments de ce tableau à l'aide d'indices démarrant à 0. L'expression $food[2] retourne "eels". On notera que le symbole @ a été changé en $ car "eels" est un scalaire. $food[3] = "orange"; L'instruction permet d'assigner le scalaire "orange" à la position 3 du tableau @food; On pourrait également utiliser l'instruction push(@food, "eggs"); afin d'ajouter le scalaire "orange" à la fin du tableau. La fonction push retourne la longueur de la nouvelle liste. L'indice du dernier élément de la liste peut se retrouver à l'aide de l'expression $#food. *On peut supprimer le dernier élément de la liste, on peut utiliser la fonction pop. Cette fonction retourne l'élément supprimé. $element = pop(@food); # $element = "eels" *Affichage d'un tableau Les instructions suivantes permettent d'afficher le tableau @food : print "@food"; .3)Les variables hachages(tableaux associatifs): Les tables de hachage sont aussi appelées tableaux associatifs (comme en PHP), dictionnaires (comme en Python), ou simplement hachages (hash en anglais) et constituent les structures de données les plus intéressantes de Perl. # Exemple de table de hachage en Perl : # %tab est une table de hachage my %tab = (nom=>"DUPONT",prenom=>"Pierre",age=>23); # $tab{nom} est l'élément "nom" de la table de hachage : il vaut "DUPONT" et c'est un scalaire print "NOM : $tab{nom}\n"; print "Prénom : $tab{prenom}\n"; print "Age : $tab{age}\n"; b)Les structures de contrôle .1)Les conditions: Le if marche comme en C comme le montre l'exemple suivant : if ($a) { print "La chaine n'est pas vide\n"; } else { print "La chaine est vide\n"; } Les tests Voici quelques tests qui retournent vrai ou faux : $a == $b # indique si $a est numériquement égal à $b? $a != $b # indique si $a n'est pas égal numériquement à $b? $a eq $b # indique si la chaîne de caractères $a est égale à la chaîne de caractères $b? $a ne $b # indique si la chaîne de caractères $a n'est pas égale à la chaîne de caractères $b? *.2) Les boucles : *foreach Pour parcourir chaque élément d'un tableau, Perl utilise une structure foreach qui s'utilise comme suit : foreach $element (@food) # Visite chaque élément de @food et le place dans $element { print "$element\n"; # affiche $element }
*Les boucles avec for et while Le for et le while marchent comme en C comme montré dans les exemples ci-dessous : for ($i = 0; $i < 10; $i++) { print "$i\n"; } $cnt = 0; open(INFO,$file); while($line = <INFO>){ #tant qu'on est pas arrivé à la fin du fichier # print "$line"; $cnt++; } print "Le fichier ci-dessus contient $cnt lignes\n";
Voici un programme Perl qui affiche le contenu du fichier "/etc/passwd" en sortie standard. #!/usr/local/bin/perl -w # $file = "/etc/passwd"; # Nom du fichier open(INFO, $file); # ouverture du fichier @lines = <INFO>; # lecture du fichier dans un tableau close(INFO); # fermeture du fichier print @lines; # affichage du tableau *La fonction open ouvre le fichier en lecture. *Le premier argument est le descripteur de fichier qui permet à Perl de se référer au fichier. *Le deuxième argument indique le nom du fichier. *La fonction close indique à Perl de fermer le descripteur de fichier. Dans le programme ci-dessus, l'information est lue dans un fichier. *Le fichier a pour descripteur INFO, et pour lire dans celui-ci, Perl utilise des angles. Ainsi, l'instruction @lines = <INFO>;lit le fichier référencé par INFO et met son contenu dans le tableau @lines. Notez que l'expression <INFO> lit le fichier entièrement en une seule fois. Ceci est dû au fait que la lecture a pour contexte une variable de tableau. Si @lines est remplacé par un scalaire $lines alors seule la prochaine ligne est lue. Dans chacun des cas, chaque ligne est stockée complètement avec son caractère "newline" à la fin. *Le fichier peut être ouvert en écriture également ou en ajout. Pour cela, il faut préfixer le nom du fichier avec > si écriture et un >> si ajout : open(INFO, $file); # ouvert en lecture open(INFO, ">$file"); # ouvert en écriture open(INFO, ">>$file"); # ouvert en ajout open(INFO, "<$file"); # ouvert en lecture *Pour écrire dans un fichier que vous avez déjà ouvert en écriture, vous pouvez utiliser l'instruction print avec un argument supplémentaire. *Pour écrire une chaîne de caractères dans un fichier dont le descripteur de fichier est INFO, utiliser print INFO "This line goes to the file.\n"; *Pour ouvrir l'entrée standard et la sortie standard, vous pouvez utilisez respectivement : open(INFO, '-'); # Ouverture de l'entrée standard open(INFO, '>-'); # Ouverture de la sortie standard
Exemple de traitement d'un formulaire en PERL
Il est très utilisé comme langage de script pour effectuer des traitements CGI sur le serveur. La syntaxe du code est proche de celle du langage C, et peut être adressé directement :
Il est compilé, puis exécuté par le moteur Perl. =
Rappels La méthode GET consiste à ajouter à l'URL la chaine d'encodage des infos du formulaire. Cet URL est passé dans la variable QUERY_STRING Pour la méthode POST, la même chaine est expédiée sur l'entrée standard du script de CGI connecté à la soumission du formulaire. Scripts de décodage méthode GET: script get.pl
$input = $ENV{"QUERY_STRING"};
@liste= split(/&/,$input);
foreach (@liste) { #dissocie la paire nom=valeur ($name,$value)= split(/=/, $_); #decode les valeurs $name =~ s/%(..)/pack("c",hex($1))/ge; $value =~ s/%(..)/pack("c",hex($1))/ge; #Traitement des données .... } méthode POST : script post.pl #recupere le contenu du buffer de l'entrée standard STDIN $in = <STDIN>; #supprime les deux CRLF insérés par le protocole HTTP chop($in); chop($in); #dissocie la chaine de caractère en une liste @liste = split(/&/,$in); #parcours de la liste foreach(@liste) { #dissocie la paire nom=valeur ($nom,$valeur)= split(/=/, $_); #decode les valeurs $nom =~ s/%(..)/pack("c",hex($1))/ge; $valeur =~ s/%(..)/pack("c",hex($1))/ge; #Traitement des donnees ... }
|
Erreurs ou confusions éventuelles
- Confusion entre Langage de programmation interprété - Langage de programmation compilé
- Confusion entre '''else if''' - '''elsif'''
- Confusion entre '''eq''' -'''=='''
- Erreur fréquente:
-Oublier que les indexes commencent par 0, et non 1. -Utiliser $_, $1, ou d’autres variables prédéfinie, puis modifier le code d’une manière qui les affecte indirectement. -Oublier que les expressions régulières sont gloutonnes, recherchant le plus long match, et non le plus court.
Questions possibles
- Pourquoi Perl ?Que puis-je faire avec Perl ?
- Est-ce que Perl tient la comparaison avec d'autres langages comme Java, Python, REXX, Scheme ou Tcl ?
- Quelle est la différence entre ``perl'' et ``Perl'' ?
- Parle-t-on de programme Perl ou de script Perl ?
- Comment rechercher un élément d'un hachage par sa valeur ?
- Comment faire l'équivalent en Perl d'une structure en C, d'une classe/d'un hachage en C++ ou d'un tableau de hachages ou de tableaux ?
- Comment obtenir l'unicité des clefs de deux hachages?
- Comment modifier un fichier binaire directement?
- Comment récupérer la date d'un fichier en perl ?
Liaisons enseignements et programmes
- Les bases de données : Il s'agit d'aborder le modèle relationnel, les systèmes de gestion de bases de données relationnelles et le langage SQL ;
et aussi les interfaces qui permettent la communication, la collecte des données et la commande des systèmes. Perl en tire une partie de sa grande puissance pour l'analyse et le traitement des données textuelles.
- Manipuler les expressions régulières: qui permettent de manipuler le texte de façon très puissante et très concise(L'acquisition de leur maîtrise peut s'avérer difficile au début, mais en vaut très largement la chandelle, aussi bien pour programmer en Perl que pour utiliser les outils classiques du shell ou les autres langages précédemment cités)en utilisant un langage simple d’usage, interprété, concis, libre et gratuit, multiplateforme et riche de bibliothèques adaptées (module CPAN).
- https://formation-perl.fr/
- https://www.orsys.lu/formation-langage-perl.html
- https://medium.com/@rhunold/comment-penser-comme-un-programmateur-le%C3%A7on-pour-pour-r%C3%A9soudre-des-probl%C3%A8mes-1f374a4b399f
}}
Aides et astuces
- Le langage Perl a un typage faible par rapport à des langages comme le langage C, de plus l'allocation de mémoire est prise en charge par l'interpréteur. * *Perl possède une caractéristique intéressante: le dimensionnement automatique des expressions, c'est-à-dire que selon le type de variable une expression sera évaluée différemment.
- Pour inclure des nouveaux chemins: avec l'option -I, par exemple pour inclure de dossier courant :
#!/usr/bin/perl -I.
- Gérer les entrées/sorties: Codage en utf8 avec l'option -C de perl : permet d'un coup et une bonne fois de tout basculer en utf8.
#!/usr/bin/perl -CSDA :
- Forcer la sortie : Pas d'instruction pour dire à Perl de vider un quelconque buffer, mais une directive pour lui indiquer que toutes les sorties doivent se faire sans attendre :
local $
Education: Autres liens, sites ou portails
Bibliographie
Pour citer cette page: ([1])
ABROUGUI, M & al, 2021. Perl. In Didaquest [en ligne]. <http:www.didaquest.org/wiki/Perl>, consulté le 21, novembre, 2024
- Sponsors Education
- Langage de programmation (Concepts)
- Algorithmique (Concepts)
- Informatique (Concepts)
- Informatique
- Algorithmique
- Programmation
- Langage de programmation
- Langage Perl
- Outils Perl
- Langages à classes
- Programmation impérative structurée
- Programmation déclarative
- Concepts
- Perl
- Perl (Concepts)
- Fiche conceptuelle didactique