Subversion Repositories eFlore/Projets.eflore-projets

Rev

Rev 65 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 65 Rev 474
1
<?php
1
<?php
2
class Outils {
2
class Outils {
-
 
3
 
3
	public static function recupererTableauConfig($parametres) {
4
	public static function recupererTableauConfig($parametres) {
4
		$tableau = array();
5
		$tableau = array();
5
		$tableauPartiel = explode(',', $parametres);
6
		$tableauPartiel = explode(',', $parametres);
6
		$tableauPartiel = array_map('trim', $tableauPartiel);
7
		$tableauPartiel = array_map('trim', $tableauPartiel);
7
		foreach ($tableauPartiel as $champ) {
8
		foreach ($tableauPartiel as $champ) {
8
			if (strpos($champ, '=') === false) {
9
			if (strpos($champ, '=') === false) {
9
				$tableau[] = $champ;
10
				$tableau[] = $champ;
10
			} else {
11
			} else {
11
				list($cle, $val) = explode('=', $champ);
12
				list($cle, $val) = explode('=', $champ);
12
				$clePropre = trim($cle);
13
				$clePropre = trim($cle);
13
				$valeurPropre = trim($val);
14
				$valeurPropre = trim($val);
14
				$tableau[$clePropre] = $valeurPropre;
15
				$tableau[$clePropre] = $valeurPropre;
15
			}
16
			}
16
		}
17
		}
17
		return $tableau;
18
		return $tableau;
18
	}
19
	}
19
 
20
 
20
	public static function extraireRequetes($contenuSql) {
21
	public static function extraireRequetes($contenuSql) {
21
		$requetesExtraites = explode(";\n", $contenuSql);
22
		$requetesExtraites = explode(";\n", $contenuSql);
22
		if (count($requetesExtraites) == 0){
23
		if (count($requetesExtraites) == 0){
23
			throw new Exception("Aucune requête n'a été trouvée dans le fichier SQL : $cheminFichierSql");
24
			throw new Exception("Aucune requête n'a été trouvée dans le fichier SQL : $cheminFichierSql");
24
		}
25
		}
25
 
26
 
26
		$requetes = array();
27
		$requetes = array();
27
		foreach ($requetesExtraites as $requete) {
28
		foreach ($requetesExtraites as $requete) {
28
			if (trim($requete) != '') {
29
			if (trim($requete) != '') {
29
				$requetes[] = rtrim(trim($requete), ';');
30
				$requetes[] = rtrim(trim($requete), ';');
30
			}
31
			}
31
		}
32
		}
32
		return $requetes;
33
		return $requetes;
33
	}
34
	}
34
 
35
 
35
	/**
36
	/**
36
	* Utiliser cette méthode dans une boucle pour afficher un message suivi du nombre de tour de boucle effectué.
37
	* Utiliser cette méthode dans une boucle pour afficher un message suivi du nombre de tour de boucle effectué.
37
	* Vous devrez vous même gérer le retour à la ligne à la sortie de la boucle.
38
	* Vous devrez vous même gérer le retour à la ligne à la sortie de la boucle.
38
	*
39
	*
39
	* @param string le message d'information.
40
	* @param string le message d'information.
40
	* @param int le nombre de départ à afficher.
41
	* @param int le nombre de départ à afficher.
41
	* @return void le message est affiché dans la console.
42
	* @return void le message est affiché dans la console.
42
	*/
43
	*/
43
	public static function afficherAvancement($message, $depart = 0) {
44
	public static function afficherAvancement($message, $depart = 0) {
44
		static $avancement = array();
45
		static $avancement = array();
45
		if (! array_key_exists($message, $avancement)) {
46
		if (! array_key_exists($message, $avancement)) {
46
			$avancement[$message] = $depart;
47
			$avancement[$message] = $depart;
47
			echo "$message : ";
48
			echo "$message : ";
48
 
49
 
49
			$actuel =& $avancement[$message];
50
			$actuel =& $avancement[$message];
50
			echo $actuel++;
51
			echo $actuel++;
51
		} else {
52
		} else {
52
			$actuel =& $avancement[$message];
53
			$actuel =& $avancement[$message];
53
 
54
 
54
			// Cas du passage de 99 (= 2 caractères) à 100 (= 3 caractères)
55
			// Cas du passage de 99 (= 2 caractères) à 100 (= 3 caractères)
55
			$passage = 0;
56
			$passage = 0;
56
			if (strlen((string) ($actuel - 1)) < strlen((string) ($actuel))) {
57
			if (strlen((string) ($actuel - 1)) < strlen((string) ($actuel))) {
57
				$passage = 1;
58
				$passage = 1;
58
			}
59
			}
59
 
60
 
60
			echo str_repeat(chr(8), (strlen((string) $actuel) - $passage));
61
			echo str_repeat(chr(8), (strlen((string) $actuel) - $passage));
61
			echo $actuel++;
62
			echo $actuel++;
62
		}
63
		}
63
	}
64
	}
-
 
65
 
-
 
66
	/**
-
 
67
	 * @link http://gist.github.com/385876
-
 
68
	 */
-
 
69
	public function transformerTxtTsvEnTableau($file = '', $delimiter = "\t") {
-
 
70
		$str = file_get_contents($file);
-
 
71
		$lines = explode("\n", $str);
-
 
72
		$field_names = explode($delimiter, array_shift($lines));
-
 
73
		foreach ($lines as $line) {
-
 
74
			// Skip the empty line
-
 
75
			if (empty($line)) continue;
-
 
76
			$fields = explode($delimiter, $line);
-
 
77
			$_res = array();
-
 
78
			foreach ($field_names as $key => $f) {
-
 
79
				$_res[$f] = isset($fields[$key]) ? $fields[$key] : '';
-
 
80
			}
-
 
81
			$res[] = $_res;
-
 
82
		}
-
 
83
		return $res;
-
 
84
	}
64
}
85
}
65
?>
86
?>