Manuel PHP

var_export

(PHP 4 >= 4.2.0, PHP 5)

var_export — Retourne le code PHP utilisé pour générer une variable

Description

mixed var_export ( mixed $expression [, bool $return ] )

var_export() retourne des données structurées sur la variable donnée. C'est le même principe que var_dump() mais avec une exception : le résultat retourné est du code PHP valide.

Liste de paramètres

expression

La variable que vous voulez exporter.

return

Si utilisé et mis à TRUE, var_export() retournera la représentation de la variable au lieu de l'afficher.

Note: Cette fonction utilise en interne le buffer de sortie avec ce paramètre, il ne peut donc pas être utilisé dans la fonction de rappel ob_start().

Valeurs de retour

Retourne la représentation de la variable lorsque le paramètre return est utilisé et évalué à TRUE. Autrement, cette fonction retournera NULL.

Historique

Version Description
5.1.0 Possibilité d'exporter des classes et des tableaux contenant des classes en utilisant la méthode magique __set_state.

Exemples

Example#1 Exemple avec var_export()

  1. <?php
  2.  
  3. $a = array (1, 2, array ("a", "b", "c"));  
  4. var_export($a);  
  5.  
  6. ?> 

L'exemple ci-dessus va afficher :

array ( 0 => 1, 1 => 2, 2 => array ( 0 => 'a', 1 => 'b', 2 => 'c', ), )
  1. <?php
  2.  
  3. $b = 3.1;  
  4. $v = var_export($b, true);  
  5. echo $v; // 3.1
  6.  
  7. ?> 

L'exemple ci-dessus va afficher :

3.1

Example#2 Exporter des classes depuis PHP 5.1.0

  1. <?php
  2. class A { public $var; }  
  3. $a = new A;  
  4. $a->var = 5;  
  5. var_export($a);  
  6. ?> 

L'exemple ci-dessus va afficher :

A::__set_state(array( 'var' => 5, ))

Example#3 Utilisation de __set_state (depuis PHP 5.1.0)

  1. <?php
  2. class A  
  3. { 
  4.    public $var1; 
  5.    public $var2; 
  6.  
  7.    public static function __set_state($an_array) 
  8.    { 
  9.       $obj = new A; 
  10.       $obj->var1 = $an_array['var1']; 
  11.       $obj->var2 = $an_array['var2']; 
  12.       return $obj; 
  13.    }  
  14. }  
  15.  
  16. $a = new A;  
  17. $a->var1 = 5;  
  18. $a->var2 = 'foo';  
  19.  
  20. eval('$b = ' . var_export($a, true) . ';'); // $b = A::__set_state(array(
  21.                            //   'var1' => 5,
  22.                            //   'var2' => 'foo',
  23.                            // ));
  24. var_dump($b);  
  25. ?> 

L'exemple ci-dessus va afficher :

object(A)#2 (2) { ["var1"]=> int(5) ["var2"]=> string(3) "foo" }

Notes

Note: Les variables de type ressource ne peuvent être exportées par cette fonction.


Remonter Remonter
L'éditeur javascript - CSS - Gentoo - Tutoriaux PHP - Tutoriels PHP - Breizh Blog