Programmation PHP/Fonctions
Définition de fonction
modifierOutre les dizaines de fonctions natives[1], PHP permet bien entendu d'écrire ses propres fonctions. Pour en définir une, il suffit d’utiliser le mot-clef function
. Comme le langage est faiblement typé, une fonction peut retourner n’importe quel type de valeur (chaîne, entier…) ou ne rien retourner du tout. Enfin, ses arguments peuvent avoir des valeurs par défaut, être nommés (depuis PHP8) et sont limités à 12 par fonction.
// foo retourne le résultat de la somme du deuxième paramètre et de 4.
// Si aucun second paramètre n'est donné, la fonction utilisera la valeur 0 par défaut.
function foo($arg1, $arg2 = 0)
{
print 'Fonction foo(' . $arg1 . ',' . $arg2 . ') donne : ';
return $arg2+4;
// tout ce qui suit ne sera jamais exécuté
}
//appel à la fonction
print foo(1,3); //affichera: Fonction foo(1,3) donne 7
print foo(5); //affichera: Fonction foo(5,0) donne 4
Notez que lorsqu'une fonction arrive à un return
, elle l'effectue puis se termine, même s'il y a d'autres instructions après.
Par ailleurs, en cas de gros volume de données à retourner, on peut utiliser yield
au lieu de return
pour les décomposer à l'aide du générateur PHP[2] (classe Generator).
Contrairement à d'autres langages, PHP ne permet pas d'appeler certains arguments par leurs noms : si l'on souhaite appeler un des derniers arguments, il faut donc définir tous ceux avant lui, même les optionnels. Toutefois pour éviter ce désagrément, on peut utiliser la classe ReflectionMethod
.
NB : il existe aussi ReflectionClass
[3].
Portée des variables
modifierLe problème de portée des variables est assez réduit en PHP. Une fonction n'a accès qu’à ses arguments, ses propres variables et aux variables globales importées statiquement (mot clé global
). De ce fait, il y a peu de confusion.
Toujours suivant le même principe, les variables utilisées dans une fonction sont toutes détruites à sa sortie (les variables globales non, bien entendu).
Exemple
|
$valeur1=10;
$valeur2=20;
function exemple($valeur)
{
global $valeur1; // récupération de la valeur globale de $valeur1
$valeur3=5;
$calcul=$valeur1+$valeur2+$valeur3+$valeur; // 10 + 0 + 5 + le paramètre qui sera entre parenthèses.
//$valeur2 n'ayant pas été définie comme valeur globale, la variable $valeur2 est donc vide.
return $calcul;
}
echo exemple(2); // affiche 17
|
On peut aussi trouver un peu plus compliqué si vous utilisez deux fichiers. L'un pour les variables, l'autre pour les traitements.
Espaces de noms
modifierDepuis PHP 5.3.0, des espaces de noms peuvent être définis pour cloisonner certains objets, à l'aide du mot clé namespace
utilisé en début de fichier[4]. Exemple de définition :
<?php
namespace Projet1;
...
Soit un fichier TestNS.php suivant :
<?php
namespace Projet1\SousProjet2;
function Fonction1()
{
echo "Fonction exécutée.\n";
echo __NAMESPACE__;
}
Le fichier doit être encodé en ANSI ou Unicode sans BOM, mais pas en Unicode seul, sous peine d’avoir l'erreur Namespace declaration statement has to be the very first statement in the script, et d'être obligé de coller le mot "namespace" à "?php").
Exemple d’utilisation :
<?php
require 'TestNS.php';
Projet1\SousProjet2\Fonction1();
require 'Projet1\SousProjet2\TestNS.php';
Références de variables
modifierLes références sont utiles lorsque l’on souhaite retourner plusieurs valeurs dans une fonction. On utilise alors le passage d'argument par référence, qui fait que quand une fonction modifie un argument, la valeur de la variable du programme principale change aussi.
Pour utiliser un argument en tant que référence, il suffit d'y mettre l'opérateur de référence, le symbole &
devant, dans la déclaration de la fonction.
Un exemple concret devrait vous faire comprendre :
Exemple
|
function foo(&$arg1, &$arg2, $arg3)
{
$arg1 = 4;
$arg2 = 6;
$arg3 = 8;
}
foo($var1, $var2, $var3);
print $var1; //affichera 4
print $var2; //affichera 6
print $var3; //affichera NULL car $arg3 n'est pas une référence (pas de &)
|
Fonctions variables
modifierOn appelle "fonction variable" une fonction dont on ne peut prédire le nombre d'arguments. Ce genre de fonction pourra se révéler pratique pour exécuter certains codes répétitifs ou le programmeur n'a pas envie de recopier le nom de la fonction pour n valeurs.
Pour cela, il faut retenir deux fonctions importantes :
- func_num_args : permet de compter le nombre d'arguments (retourne true ou false).
- func_get_args : permet de récupérer la valeur d’un argument (retourne un tableau de valeur)[5].
Ces deux fonctions ne peuvent s'utiliser qu’à l'intérieur d’une fonction; dans le cas contraire un message d'erreur s'affichera.
Exemple
|
function afficher_variables ()
{
$nb_args = func_num_args();
$list_args = func_get_args();
for ($i = 0; $i < $nb_args; $i++) {
echo $list_args[$i].' ';
}
}
$var1 = 'programmeur';
afficher_variables('Je suis', $var1, ', c\'est utile', ', c\'est intéressant.'); // Et on peut en rajouter autant que nécessaire.
|
Le code se comprend de lui-même. Il affichera : Je suis programmeur, c’est utile, c’est intéressant.
Fonctions de rappel
modifierPour passer une fonction en argument d'une autre, il faut utiliser call_user_func()
. Ex :
function fonctionAppelante(string $nomDeFonctionAppelee)
{
return call_user_func($nomDeFonctionAppelee);
}
Fonctions anonymes
modifierUne fonction sans nom peut être stockée dans une variable permettant de l'appeler. Le mot clé use
permet d'injecter des variables globales dedans. Ex :
$variableGlobale = 'Hello';
$fonctionAnonyme = function ($argument) use ($variableGlobale) {
return $variableGlobale.' '.$argument.PHP_EOL;
};
echo $fonctionAnonyme('World'); // Hello World
echo $fonctionAnonyme('You'); // Hello You
Fonctions fléchées
modifierDepuis PHP7.4, on peut définir une fonction anonyme avec l'opérateur "=>" et le mot réservé fn
. Ex :
$fonctionFlechee = fn($argument) => $variableGlobale.' '.$argument.PHP_EOL;
echo $fonctionFlechee('World'); // Hello World
echo $fonctionFlechee('You'); // Hello You
Fonctions prédéfinies
modifierVoici une liste des fonctions globales prédéfinies en PHP les plus usuelles.
print()
(aliasecho
) : affiche le contenu de la variable placée en paramètre.printf()
et dérivés (ex :sprintf
) : print formaté, affiche un texte dont on remplace les marqueurs, numérotables, par les variables en paramètre[6]. Exemple :
printf('Compteur : %s. ', 1); // Compteur : 1.
printf('Compteur : %s. ', 2); // Compteur : 2.
printf('Compteur : %s, taille : %s. ', 3, 1); // Compteur : 3, taille : 1.
printf('Compteur : %2$s, taille : %1$d. ', 1, 4); // Compteur : 4, taille : 1.
printf('Compteur : %1$d, taille : %1$d. ', 5); // Compteur : 5, taille : 5.
echo vsprintf('Tailles : %d, %d, %d, %d', [1, 2, 3, 4]); // Tailles : 1, 2, 3, 4
Les types suivants sont généralement utilisés :
- d : digit
- f : float
- s : string
- Pour échapper les "%" pour sont interprétés par ces fonctions, ce n'est pas "\" mais "%".
- Ne pas utiliser les doubles quotes sous peine de
Undefined variable: d
.
sleep($secondes)
: attend un certain nombre de secondes (utilisation déconseillée quand un humain doit attendre un résultat).call_user_func_array('maFonction', 'mesArguments')
: exécute une fonction à partir de son nom en chaîne de caractères.getenv()
: affiche toutes les variables d'environnement, ou celle demandée en paramètre.ignore_user_abort(true)
: ("false" par défaut) continue l'exécution d'un script lancé par un utilisateur, même s'il change de page ou clique annule le chargement.header()
: ajoute une clé dans l'en-tête HTTP de la réponse.ini_get()
: lit le php.ini.ini_set()
: modifie le php.ini le temps de l'instance.set_time_limit()
: redéfinit la limite de temps du php.ini.require()
: importe le code PHP d'un autre fichier, avec une erreur si c'est impossible[7].require()_once
: idem en garantissant que chaque fichier n'est ajouté qu'une fois.include()
: importe le code PHP d'un autre fichier, sans erreur si c'est impossible.include_once()
: idem en garantissant que chaque fichier n'est ajouté qu'une fois.getmypid()
: retourne l'ID du processus courant dans l'OS.
Sur les chaînes
modifiertrim($string)
: supprimer les espaces et retours chariots en début et fin de chaîne par défaut. Son second paramètre permet de remplacer les symboles à retirer.strip_tags()
: supprime les balises HTML de la chaîne mentionnée en paramètre 1, en conservant ceux en paramètre 2 (sous la forme d'une chaine comme '<p><br>').ucfirst()
: met une majuscule en début de chaîne.lcfirst()
: met une minuscule en début de chaîne.strtoupper()
: met en lettres capitales toute la chaîne.strtolower()
: met en bas de casse toute la chaîne.strlen()
: compte la taille d'une chaîne en octets. Pour avoir le nombre de caractères, utilisermb_strlen()
(pour multibyte).str_contains($chaine, $cle)
: cherche si une chaîne contient une sous-chaîne.- <codestr_starts_with($chaine, $cle) : vérifie si une chaîne commence par une sous-chaîne.
str_replace($ancien, $nouveau, $texte)
: remplace des caractères par d'autres dans un texte ou un tableau[8].str_ireplace($ancien, $nouveau, $texte)
: fait la même chose en ignorant la casse.strtr($texte, $ancien, $nouveau)
(string translate) : réputée plus rapide questr_replace
[9].strpos($meubleDeFoin, $aiguille)
[10] : première position d'une sous-chaine. Attention : ne jamais utiliser comme si elle renvoyait un booléen () car si la recherche est en première position (0) elle sera considérée comme fausse avec le typage faible. Il faut tester l'existence avecif (strpos())
if (false !== strpos())
.stripos($meubleDeFoin, $aiguille)
: fait la même chose en ignorant la casse.strrpos($meubleDeFoin, $aiguille)
: dernière position d'une sous-chaine.substr($texte, $debut , $fin)
: tronque un texte en sous-chaine. Utilisermb_substr
en Unicode.- Pour accéder à un seul caractère d'une chaine, PHP peut la considérer comme un tableau (ex :
$chaine[0]
). - Ex :
echo substr('Hello World', 0, 2); // "He" : les deux premiers caractères
echo substr('Hello World', -2); // "ld" : les deux derniers caractères
echo substr('Hello World', 0, -1); // "Hello Worl" : tout sauf le dernier caractère
substr_count($chaine, $sous-chaine)
: compte le nombre de sous-chaine dans une chaine.str_pad()
: complète une chaine avec un caractère pour qu'elle atteigne la taille demandée si ce n'était pas le cas. Ex :
echo str_pad(10, 2, '0'); // 10
echo str_pad(9, 2, '0'); // 90
echo str_pad(9, 2, '0', STR_PAD_LEFT); // 09
eval($chaine)
: exécute une chaine comme un script PHP.count_chars($chaine)
: renvoie un tableau avec en clés chaque caractère de la chaine, et en valeur son nombre d'occurrences. Pratique pour détecter les anagrammes.
Encodage
modifier- Pour plus de détails voir : Coder avec Unicode/Conversion#PHP.
utf8_encode($chaine)
etutf8_decode($chaine)
sont dépréciée en PHP 8.2, il faut utiliser à la placemb_convert_encoding($chaine, 'UTF-8')
etmb_convert_encoding($chaine, 'ISO-8859-1')
.
URLs
modifierparse_url()
: découpe une chaîne en partie d'une adresse URL (protocole, domaine et chemin d'accès).http_build_query()
: crée une URL à partir d'un tableau d'arguments GET. Par défaut le séparateur est "&" (3e argument). Cette fonction échappe les séparateurs. Ex :
php -r "var_dump(http_build_query(['x' => 1, 'y' => 2]));"
string(7) "x=1&y=2"
php -r "var_dump(http_build_query(['x' => '1/', 'y' => '2&'], '/', '/'));"
string(13) "x=1%2F/y=2%26"
Sur les nombres
modifierpow($nombre, $exposant)
(power) : élève un nombre à la puissance de l'exposant donné.sqrt($nombre)
(square root) : racine carrée.max($nombre1, $nombre2, ...)
[11] : affiche le plus grand nombre parmi ceux en paramètres.min($nombre1, $nombre2, ...)
: affiche le plus petit nombre d'une liste.round($nombre)
: arrondit un nombre à l'entier le plus proche, ou selon une précision en deuxième paramètre s'il est renseigné[12]. Exemple :
echo round(5.49); // 5 echo round(5.50); // 6 echo round(5.555, 2); // 5.56
number_format($nombre, 2, ',', ' ')
: formate un nombre donné, où "2" représente le nombre de chiffres après la virgule, "," le séparateur décimal et " " le séparateur de milliers.
Ne jamais comparer des nombres issus du number_format()
car les séparateurs faussent les calculs. Exemple :
-1000.00 < -1000.02 // false -1,000.00 < -1,000.02 // -1
Bufferisation de sortie
modifierLa bufferisation de sortie bloque l'envoie de données au client HTTP pour les mettre dans une mémoire tampon à la place[13].
ob_start()
: démarre l'utilisation du tampon.ob_get_contents
: affiche le contenu du tampon.ob_clean()
: efface le tampon sans l'envoyer.ob_flush()
: envoie le tampon au client.
Références
modifier- ↑ http://php.net/manual/fr/indexes.functions.php
- ↑ http://php.net/manual/fr/language.generators.syntax.php
- ↑ http://php.net/manual/fr/reflectionclass.getdoccomment.php
- ↑ http://php.net/manual/fr/language.namespaces.rationale.php
- ↑ http://php.net/manual/fr/ref.funchand.php
- ↑ http://php.net/manual/fr/function.sprintf.php
- ↑ https://www.alsacreations.com/article/lire/254-le-point-sur-la-fonction-include-php.html
- ↑ http://php.net/manual/fr/function.str-replace.php
- ↑ https://www.keycdn.com/blog/php-performance#10-use-the-strongest-str-functions
- ↑ http://php.net/manual/fr/function.strpos.php
- ↑ http://php.net/manual/fr/function.max.php
- ↑ http://php.net/manual/fr/function.round.php
- ↑ https://www.php.net/manual/fr/ref.outcontrol.php