Précédent   Forum des professionnels en informatique > PHP > Langage > Contribuez

Contribuez Proposez vos articles, cours, tutoriels, FAQ, sources, etc. pour PHP

Réponse
 
Outils de la discussion
Vieux 27/08/2003, 14h51   #1 (permalink)
Responsable PHP
 
Avatar de Yogui
 
Date d'inscription: février 2004
Localisation: Yonne
Messages: 13 734
Par défaut Vos meilleurs Codes Source

Bonjour à tous.

Merci de poster ci-après ce que vous souhaitez mettre à la disposition de tous (votre code, ou celui d'autres sur ce forum). Ce code sera entièrement libre et gratuit.

Ce fil est un espace de stockage temporaire de vos codes avant intégration dans la page Code sources.

Précisez à chaque fois :
- Titre
- Auteur
- Champ d'application

Merci de nous aider dans ce sens et ainsi de permettre d'aider encore plus de monde.

L'équipe PHP.

Dernière modification par Yogui ; 17/10/2006 à 17h15.
Yogui est actuellement connecté   Envoyer un message privé Réponse avec citation
Vieux 15/09/2004, 20h13   #2 (permalink)
Membre émérite
 
Avatar de torvalds17
 
Date d'inscription: mars 2004
Localisation: 92
Âge: 25
Messages: 745
Par défaut

Transformation d'un nombre de chiffres (entier) en lettres (en français, limité à 999,999,999,999)

ça marche en regroupant les chiffres par series de 3 :

Code :
<?php
 
function convertitNombreEnLettres($nombreAConvertir)
{
    $tablePuissancesDeDix = array("", "mille", "millions", "milliards");// ce qu'on affichera apres chaque serie de trois
    $tableConversionEtapeDeux = array("", "dix", "vingt", "trente", "quarante", "cinquante", "soixante", "soixante", "quatre-vingt", "quatre-vingt");// equivalent du second chiffre de la serie de 3 (la dizaine)
    $tableConversionEtapeUnOuTrois = array("", "un", "deux", "trois", "quatre", "cinq", "six", "sept", "huit", "neuf");// equivalent du premier et du troisieme chiffre de la serie de 3
    $tableConversionDeLaDizaineQuiFaitChier = array("", "onze", "douze", "treize", "quatorze", "quinze", "seize");
    $nombreAConvertir = number_format($nombreAConvertir);// on formate le nombre "a l'anglaise" avec des virgules entre les milliers
    $tableauTemporaire = explode(',', $nombreAConvertir);// on passe les milliers dans un tableau
    for($i=0; $i<count($tableauTemporaire); $i++)// on parcourt le tableau, par milliers donc
    {
        for($j=0; $j<strlen($tableauTemporaire[$i]); $j++)// on parcourt les 3 caracteres (ou moins) du millier en cours
        {
            switch($j)
            {
                case strlen($tableauTemporaire[$i])-3://si on est dans les centaines
                    if(substr($tableauTemporaire[$i], $j, 1) > 0)
                    {
                        if(substr($tableauTemporaire[$i], $j, 1) > 1)
                            echo $tableConversionEtapeUnOuTrois[substr($tableauTemporaire[$i], $j, 1)];
                        echo " cents ";
                    }
                    break;
                case strlen($tableauTemporaire[$i])-2:// si on est dans les dizaines
                    if(substr($tableauTemporaire[$i], $j, 1) > 1)
                        echo $tableConversionEtapeDeux[substr($tableauTemporaire[$i], $j, 1)];
                    if(substr($tableauTemporaire[$i], $j, 1) == 1 || substr($tableauTemporaire[$i], $j, 1) == 7 || substr($tableauTemporaire[$i], $j, 1) == 9)
                        if(substr($tableauTemporaire[$i], $j+1, 1) > 6)
                            echo "-dix";
                    break;
                case strlen($tableauTemporaire[$i])-1:// si on est dans les unites
                    if(substr($tableauTemporaire[$i], $j, 1) == 1)
                        echo " et ";
                    if(substr($tableauTemporaire[$i], $j-1, 1) == 1 ||substr($tableauTemporaire[$i], $j-1, 1) == 7 || substr($tableauTemporaire[$i], $j-1, 1) == 9)
                        if(substr($tableauTemporaire[$i], $j, 1) < 7)
                            echo "-".$tableConversionDeLaDizaineQuiFaitChier[substr($tableauTemporaire[$i], $j, 1)];
                        else
                            echo "-".$tableConversionEtapeUnOuTrois[substr($tableauTemporaire[$i], $j, 1)];
                    else
                        echo "-".$tableConversionEtapeUnOuTrois[substr($tableauTemporaire[$i], $j, 1)];
                    break;
            }
        }
        echo " ".$tablePuissancesDeDix[count($tableauTemporaire)-$i-1]." ";// à quelle multiple de 10^3 on est ?
    }
}
 
convertitNombreEnLettres(124036977);
?>
ce n'est peut etre pas optimal, alors si vous avez des suggestions ou si vous trouvez des bugs, je suis ouvert ;-)

[edit]et si certaines parties non commentées vous echappent, vous pouvez me contacter ;-)[/edit]
__________________
référence PHP, référence JavaScript,
mettez-les dans vos marque-pages et lisez-les avant de poster ici ;-)

Mes scripts web

Dernière modification par Kerod ; 10/10/2006 à 01h04. Motif: Ajouté Pages Sources
torvalds17 est déconnecté   Envoyer un message privé Réponse avec citation
Vieux 14/10/2004, 20h37   #3 (permalink)
Membre émérite
 
Avatar de torvalds17
 
Date d'inscription: mars 2004
Localisation: 92
Âge: 25
Messages: 745
Par défaut

Sauvegarder la structure et les données d'une base MySQL
Code :
function dumpMySQL($serveur, $login, $password, $base, $mode)
{
    $connexion = mysql_connect($serveur, $login, $password);
    mysql_select_db($base, $connexion);
    
    $entete = "-- ----------------------\n";
    $entete .= "-- dump de la base ".$base." au ".date("d-M-Y")."\n";
    $entete .= "-- ----------------------\n\n\n";
    $creations = "";
    $insertions = "\n\n";
    
    $listeTables = mysql_query("show tables", $connexion);
    while($table = mysql_fetch_array($listeTables))
    {
        // si l'utilisateur a demandé la structure ou la totale
        if($mode == 1 || $mode == 3)
        {
            $creations .= "-- -----------------------------\n";
            $creations .= "-- creation de la table ".$table[0]."\n";
            $creations .= "-- -----------------------------\n";
            $listeCreationsTables = mysql_query("show create table ".$table[0], $connexion);
            while($creationTable = mysql_fetch_array($listeCreationsTables))
            {
              $creations .= $creationTable[1].";\n\n";
            }
        }
        // si l'utilisateur a demandé les données ou la totale
        if($mode > 1)
        {
            $donnees = mysql_query("SELECT * FROM ".$table[0]);
            $insertions .= "-- -----------------------------\n";
            $insertions .= "-- insertions dans la table ".$table[0]."\n";
            $insertions .= "-- -----------------------------\n";
            while($nuplet = mysql_fetch_array($donnees))
            {
                $insertions .= "INSERT INTO ".$table[0]." VALUES(";
                for($i=0; $i < mysql_num_fields($donnees); $i++)
                {
                  if($i != 0)
                     $insertions .=  ", ";
                  if(mysql_field_type($donnees, $i) == "string" || mysql_field_type($donnees, $i) == "blob")
                     $insertions .=  "'";
                  $insertions .= addslashes($nuplet[$i]);
                  if(mysql_field_type($donnees, $i) == "string" || mysql_field_type($donnees, $i) == "blob")
                    $insertions .=  "'";
                }
                $insertions .=  ");\n";
            }
            $insertions .= "\n";
        }
    }
 
    mysql_close($connexion);
 
    $fichierDump = fopen("dump.sql", "wb");
    fwrite($fichierDump, $entete);
    fwrite($fichierDump, $creations);
    fwrite($fichierDump, $insertions);
    fclose($fichierDump);
    echo "Sauvegarde réalisée avec succès !!";
}
à appeler sous la forme :
Code :
dumpMySQL("127.0.0.1", "root", "", "ma_base", 3);
comme toujours, si vous rencontrez un bug, ou si vous voyez des possibilités d'ameliorations. pour vos propositions ;-)

[edit]je viens de la mettre sous forme de fonction, ce qui est plus propre, et qu'on peut appeler avec des parametres... ;-)[/edit]
__________________
référence PHP, référence JavaScript,
mettez-les dans vos marque-pages et lisez-les avant de poster ici ;-)

Mes scripts web

Dernière modification par Kerod ; 15/09/2006 à 00h12. Motif: Ajouté page Sources
torvalds17 est déconnecté   Envoyer un message privé Réponse avec citation
Vieux 07/03/2005, 01h48   #4 (permalink)
Rédacteur
 
Avatar de genova
 
Date d'inscription: septembre 2004
Messages: 481
Envoyer un message via MSN à genova
Par défaut

Etant donné que je me lance dans un projet assez gros ou je devrais connaitre en permanance le temps d'éxécution de mes scripts à la demande, je me suis dit que faire une classe de benchmark serait utile (et tant qu'à faire autant la partager). Cette classe toute con permet de faire des benchmark (de voir le temps d'éxécution de son script à différent endroits clefs) très facilement tout en ayant deux trois statistiques (pourcentage d'éxécution du script notament) dans un joli tableau, l'utilisation :
Code :
<?php
 
// On inclu la classe
include('class_benchmark.php');
 
// On intialise le benchmark
$bench = new bench();
 
sleep(2);
 
// On pose un marqueur, l'argument est le nom du marqueur
$bench->set_mark(1);
 
sleep(3);
 
// Fin du benchmark
$bench->finish();
 
?>
Et voici la classe :
Code :
<?php
class bench
{
	// Contient les différents temps pour les étapes
	var $data = array();
 
	// Temps final
	var $end = 0;
 
	// Temps de départ
	var $start = 0;
 
	/*
	** Constructeur de la classe bench.
	** Initialise le temps de départ.
	*/
	function bench()
	{
		$this->start = $this->get_time();
	}
 
	/*
	** Créé un marqueur qui retient le temps écoulé.
	** -----
	** $name :: Nom du marqueur.
	*/
	function set_mark($name)
	{
		$this->data[] = array('name' => $name, 'time' => $this->get_time());
	}
 
	/*
	** Sauvegarde le temps final et affiche tous les temps des marqueurs,
	** avec un certain nombre de statistique.
	*/
	function finish()
	{
		$this->end = $this->get_time();
		$total = $this->end - $this->start;
 
		echo '
			<table width="800" align="center" style="border: solid 1px #000000;">
				<tr>
					<td style="background-color: #cccccc; font-weight: bold; text-align: center;" colspan="4">Benchmark</td>
				</tr>
				<tr>
					<td style="background-color: #dddddd; width: 400px; text-align: center;" colspan="2">Temps d\'éxécution total :</td>
					<td style="background-color: #eeeeee; text-align: center;" colspan="2">' . ($total) . '</td>
				</tr>
				<tr>
					<td style="background-color: #cccccc; font-weight: bold; text-align: center;" colspan="4">Marqueurs</td>
				</tr>
				<tr>
					<td style="background-color: #dddddd; width: 200px; text-align: center; font-weight: bold;">Nom du marqueur</td>
					<td style="background-color: #eeeeee; width: 200px; text-align: center; font-weight: bold;">Temps du marqueur</td>
					<td style="background-color: #eeeeee; width: 200px; text-align: center; font-weight: bold;">Temps passé</td>
					<td style="background-color: #dddddd; width: 200px; text-align: center; font-weight: bold;">Pourcentage d\'éxécution</td>
				</tr>
				<tr>
					<td style="background-color: #dddddd; width: 200px; text-align: center;">Temps de départ :</td>
					<td style="background-color: #eeeeee; width: 200px; text-align: center;">' . ($this->start) . '</td>
					<td style="background-color: #eeeeee; width: 200px; text-align: center;">' . (0) . '</td>
					<td style="background-color: #dddddd; width: 200px; text-align: center;">0%</td>
				</tr>
		';
		foreach ($this->data AS $v)
		{
			$time_added = $v['time'] - $this->start;
			$percent = ($time_added / $total) * 100;
			echo '
				<tr>
					<td style="background-color: #dddddd; width: 200px; text-align: center;">Marqueur ' . $v['name'] . ' :</td>
					<td style="background-color: #eeeeee; width: 200px; text-align: center;">' . ($v['time']) . '</td>
					<td style="background-color: #eeeeee; width: 200px; text-align: center;">' . ($time_added) . '</td>
					<td style="background-color: #dddddd; width: 200px; text-align: center;">' . round($percent) . '%</td>
				</tr>
			';
			$before = $v['time'];
		}
		echo '
				<tr>
					<td style="background-color: #dddddd; width: 200px; text-align: center;">Temps d\'arrivé :</td>
					<td style="background-color: #eeeeee; width: 200px; text-align: center;">' . ($this->end) . '</td>
					<td style="background-color: #eeeeee; width: 200px; text-align: center;">' . ($total) . '</td>
					<td style="background-color: #dddddd; width: 200px; text-align: center;">100%</td>
				</tr>
			</table>
		';
	}
 
	/*
	** Renvoie un temps pour le benchmark.
	*/
	function get_time()
	{
		$ary = explode(' ', microtime());
		return ($ary[0] + $ary[1]);
	}
}
?>
__________________
Testez le forum Fire Soft Board, un forum libre, gratuit et français.

Système de template de phpBB - Lisez la FAQ PHP avant toute question si vous débuttez en PHP.
genova est déconnecté   Envoyer un message privé Réponse avec citation
Vieux 09/04/2005, 11h30   #5 (permalink)
Membre à l'essai
 
Date d'inscription: août 2004
Messages: 40
Envoyer un message via MSN à Antickriszt
Par défaut

bonjour à tous... voilà un petit script qui permet de générer des galeries d'images...
la page index.php doit être uploadée au même niveau qu'un répertoire de dossiers contenant soit des sous dossiers soit des galeries...
le script s'occupe de générer les pages pour la navigation dans les sous dossiers, un moteur de recherche (ultra simple) pour rechercher des galeries , ainsi que les vignettes d'apercu des images dans les galeries...

un petit exemple d'utilisation de mon script

télécharger l'archive

et pour toute question, antickriszt@hotmail.com
(pas eu le temps de faire un readme complet, désolé....)

Dernière modification par Kerod ; 15/09/2006 à 00h12. Motif: Ajouté page Sources
Antickriszt est déconnecté   Envoyer un message privé Réponse avec citation
Vieux 21/05/2005, 04h19   #6 (permalink)
Membre à l'essai
 
Date d'inscription: juin 2004
Messages: 43
Par défaut

Script permettant à des personnes qui ont une adresse IP dynamique (non Fixe quoi )et d'un hébergeur PHP d'avoir une redirection automatique sur leur machine ou d'un affichage "SERVEUR INDISPONIBLE" si le serveur web est coupé.
Je l'utilise pour avoir une redirection de mon site sur Free vers mon PC

1/ Le fichier ip.php sur le serveur de Free
Code :
 
<?
header("Expires: Mon, 26 Jul 1997 05:00:00 GMT");
header("Last-Modified: " . gmdate("D, d M Y H:i:s") . " GMT"); 
header("Cache-Control: no-store, no-cache, must-revalidate");
header("Cache-Control: post-check=0, pre-check=0", false);
header("Pragma: no-cache");
echo $_SERVER['REMOTE_ADDR'];
?>
 
2/Une page hs.php qui affiche un message "serveur indisponible"

3/Un script lancé en local par la commande
Citation:
php -f redirection_free.php
il faut pour cela que votre PHP soit configuré pour fonctionner en mode CGI (je crois ça se dit comme cela, je suis pas sûr car je débute sur PHP et tout ce qui concerne le développement sur le web alors sorry si je raconte des anneries)

4/le script redirection_free.php
Code :
 
<?php
$old_adresse    = "";
$adrese_ip        = "";
 
//-o0o- Boucle infinie                                                -o0o-
//-o0o---------------------------------------------------------------o0o-
while (1) {
    //-o0o- Lecture du fichier ip.php se trouvant sur le site de    -o0o-
    //-o0o- Free qui va nous renvoyer $_SESSION['REMOTE_ADDR']        -o0o-
    //-o0o-----------------------------------------------------------o0o-
    $adresse_ip = "";
    if ( $id_fic = @fopen("http://login.free.fr/ip.php",'rb')) {
        if ($id_fic) {
            while(!feof($id_fic)) {
                $adresse_ip .= fread($id_fic,16);
            }
                                                fclose($id_fic);
        }                
    }
    if ($id_fic) {
        if ($old_adresse != $adresse_ip) {
            //-o0o- Nouvelle adresse IP => Création d'une nouvelle page    -o0o-
            //-o0o- de redirection pour le serveur Free avec nouvelle     -o0o-
            //-o0o- adresse IP                                            -o0o-
            //-o0o-------------------------------------------------------o0o-
            $source_file    = "temp";
            echo date("F j, Y, g:i a")." : Nouvelle adresse IP : ".$adresse_ip." \n";
            if ( $id_fic = fopen($source_file,'wb')) {
                echo "Fichier ".$source_file." ouvert : ".$id_fic." \n";
                $contenu = "<?php \n";
                $contenu .= "    if (! @fopen('http://".$adresse_ip."/ALIAS_SITE_SI_Y_EN_A_1/', 'r')) { \n";
                $contenu .= "        header('Location: hs.php'); \n";
                $contenu .= "    } else { \n";
                $contenu .= "        header('Location: http://".$adresse_ip."/ALIAS_SITE_SI_Y_EN_A_1/'); \n";
                $contenu .= "    } \n";
                $contenu .= "?";
                $contenu .= "> \n";
    //            echo "Contenu de la page : \n";
    //            echo $contenu;
                if (fwrite($id_fic,$contenu,strlen($contenu))) {
                    fclose($id_fic);
                    echo "Fichier temporaire OK \n";
                    
                    //-o0o- le fichier temporaire a été correctement créé    -o0o-
                    //-o0o- Envoi par FTP sur le serveur de Free            -o0o-
                    //-o0o---------------------------------------------------o0o-
                    echo "Ouverture connection FTP \n";
                    
                    //-o0o- Paramètre de connection                            -o0o-
                    //-o0o---------------------------------------------------o0o-
                    $ftp_server         = "ftpperso.free.fr";
                    $ftp_user_name        = "login";
                    $ftp_user_pass        = "password";
                    $destination_file    = "index.php";
                    
                    $conn_id = ftp_connect($ftp_server); 
                    $login_result = ftp_login($conn_id, $ftp_user_name, $ftp_user_pass); 
                    if ((!$conn_id) || (!$login_result)) { 
                       echo "La connection FTP a échouée ! \n";
                       echo "Tentative de connection au server".$ftp_server."pour l'utilisateur".$ftp_user_name." \n";
                       exit; 
                    } else {
                        echo "Connection réussie \n";
                    }
                    $upload = ftp_put($conn_id, $destination_file, $source_file, FTP_BINARY); 
                    if (!$upload) { 
                        echo "Echec de l'Upload du fichier ! \n";
                    } else {
                        echo "Fichier envoyé avec succès. \n";
                    }
                    ftp_close($conn_id);
                    
                    //-o0o- Tout s'est déroulé correctement => suppression    -o0o-
                    //-o0o- du fichier temporaire et mémorisation de la     -o0o-
                    //-o0o- nouvelle adresse IP                                -o0o-
                    //-o0o---------------------------------------------------o0o-
                    unlink($source_file);
                    $old_adresse = $adresse_ip;
                } else
                {
                    echo "Erreur d'écriture dans le fichier temporaire \n";
                }
            }
        }
    }
    //-o0o- Attente de 10 minutes                                        -o0o-
    //-o0o---------------------------------------------------------------o0o-
    sleep(3000);
}
?>
 
comme je l'ai écris plus haut je débute sur PHP alors il est possible qu'il y ai quelques petits soucis mais chez moi ça a l'air de fonctionner correctement

il reste plus qu'à lancer un raccourcis qui exécute la commande php -f redirection_free.php (racourcis qui sera créé sur son bureau) pour lancer la redirection automatique.

et ainsi je peux avoir une connection sur mon PC en tapant l'adrese http://login.free.fr sans avoir à connaître mon IP

Dernière modification par Yogui ; 30/04/2006 à 14h01.
Leviathan_72 est déconnecté   Envoyer un message privé Réponse avec citation
Vieux 11/08/2005, 14h40   #7 (permalink)
Invité régulier
 
Date d'inscription: juin 2005
Âge: 25
Messages: 19
Envoyer un message via MSN à HuZimA
Par défaut

quelque fonction de connexion au base de données:

Le fichier a inclure dans chaque fonction :

Code :
 
<?
  	  $Host	     = "IP du serveur";
	  $Utilisateur   = "utilisateur";
	  $Pass	     = "mot de passe";
	  $Bdd	     = "base de données";
?>
 
Lecture d'un champs:
Code :
 
Function BDDLecture ($Table, $ChampDonne, $ChampValue, $ChampVoulu)
	 {
	 include ('Bdd.sit');
	 
	 $Return="inconnu";
         $In=mysql_connect ($Host, $Utilisateur, $Pass) or die ("Connexion impossible");
         if (mysql_select_db ($Bdd, $In)){
            if ($enregist=mysql_fetch_object(mysql_query ("SELECT*FROM $Table  WHERE  $ChampDonne = '$ChampValue'", $In)))
     	       $Return=$enregist->$ChampVoulu;}
         mysql_close ($In);
         return $Return;
	 }
 
où la variable :
$Table et la table dans laquelle on souhaite lire
$ChampDonne et le champ à partir du quel on se refère
$ChampValue et la valeur du champs auquel on se refere
$ChampVoulu et la valeur du champs que l'on souhaite avoir

La fonction enregistrement:

Code :
 
Function BDDSave ($Table,$Champs,$Valeurs)
	 {
	 include ('Bdd.sit');
	 
	 $Colonne="(";
         $Ligne="('";
   	 $i=$Champs[1]+1;
   	 do{
           $Colonne="$Colonne$Champs[$i],";
      	   $i--;
     	   if ($i==2)
              {$Colonne="$Colonne$Champs[$i])";
	      $i--;}
           }while ($i>=2);
         $i=$Valeurs[1]+1;
         do{
           $Ligne="$Ligne$Valeurs[$i]','";
           $i--;
           if ($i==2)
              {$Ligne="$Ligne$Valeurs[$i]')";
	      $i--;}
           }while ($i>=2);
         $In=mysql_connect ($Host, $Utilisateur, $Pass) or die ("Connexion impossible");
     	 if (mysql_select_db ($Bdd, $In))
            mysql_query ("insert into $Table $Colonne values $Ligne", $In);
         mysql_close ($In);
	 }
 
où la variable :
$Table et la table dans laquelle on souhaite enregistrer
$Champs et un tableau, avec case 1 le nombre de champs case 2 à l'infini les champs que l'on souhaite enregistrer
ex: $Champs = array (1=> '2', 'user','id');
$Valeurs et un tableau, avec la case 1 le nombre de valeur, case 2 à l'infini les valeurs des champs mentionné dans $Champs
ex: $Valeurs = array (1=> '2','HuZimA','12');
!!! Atention !!! le nombre de la case 1 dans $Champs doit être identique au nombre mentionné dans la case 1 de $Valeur, et les données fourni dans chacun des tableaux doit être dans le même ordre, soit case de $Champs = 'user' la ces 2 de $Valeur doit renseigner pour le champs 'user'.

La fonction update:

Code :
 
Function BDDUpdate ($Table,$Champs,$Valeurs)
	 {
	 include ('Bdd.sit');
	
	 $Return="Mauvais";
 	 $i=$Champs[1]+2;
 	 $Changement="$Champs[$i]=\"$Valeurs[$i]\" ";
 	 do{
 	   $i--;
 	   if ($i>="3")
 	   $Changement="$Changement , $Champs[$i]=\"$Valeurs[$i]\"";
 	   if ($i="2")
 	   $Changement="$Changement WHERE $Champs[$i]=\"$Valeurs[$i]\" LIMIT 1 ;";
 	   }while ($i<="1");
  	 $In=mysql_connect ($Host, $Utilisateur, $Pass) or die ("Connexion impossible");
     	 if (mysql_select_db ($Bdd, $In)){
     	    if (mysql_query ("UPDATE $Table SET $Changement", $In))
	       $Return="Bon";}
	 mysql_close ($In);
         return $Return;
	 }
 
où la variable :
$Table et la table dans laquelle on souhaite enregistrer
$Champs et un tableau, avec case 1 le nombre de champs, la case 2 et le champs que l'on appel pour referencé la l'enregistrement à changer, la case 3 à l'infini les champs que l'on souhaite enregistrer
ex: $Champs = array (1=> '2', 'Email','user','id');
$Valeurs et un tableau, avec la case 1 le nombre de valeur,la case 2 et la valeur du champs que l'on a appellé pour referencer l'enregistrement a changer case 3 à l'infini les valeurs des champs mentionné dans $Champs
ex: $Valeurs = array (1=> '2', 'aaa@hotmail.fr','HuZimA','12');
!!! Atention !!! le nombre de la case 1 dans $Champs doit être identique au nombre mentionné dans la case 1 de $Valeur, et les données fourni dans chacun des tableaux doit être dans le même ordre, soit case de $Champs = 'user' la ces 2 de $Valeur doit renseigner pour le champs 'user'.

La fonction effacer:

Code :
 
Function BDDErase($Table, $Champs, $Valeur)
	 {
 	 include ('Bdd.sit');
	
	 $Return="Mauvais";
         $In=mysql_connect ($Host, $Utilisateur, $Pass) or die ("Connexion impossible");
         if (mysql_select_db ($Bdd, $In)){
            if (mysql_query ("DELETE FROM `$Tableau[1]`  WHERE  $Tableau[2] = " . "\"$Tableau[3]\"", $In))
	       $Return="Bon";}
         mysql_close ($In);
         return $Return;
	 }
 
où la variable :
$Table et la table dans laquelle on souhaite effacer
$Champs et le champ à partir du quel on se refère
$Valeur et la valeur du champs auquel on se refere
HuZimA est déconnecté   Envoyer un message privé Réponse avec citation
Vieux 29/08/2005, 19h04   #8 (permalink)
Invité régulier
 
Date d'inscription: juin 2002
Messages: 12
Par défaut

Ceci est une class pour lister un repertoire ainsi que tous ses sous repertoires et les fichiers d'une manièere assez "organisée"

Code :
class folder_recursive
{
	function folder_recursive (&$array, $path = './')
	{
		if (!is_dir ($path))
			return FALSE;
 
		if (!is_array ($array)) 
			$array = array ();
 
		$dir = @opendir ($path);
 
		while ($res = @readdir ($dir))
		{
			if (($res == '.') || ($res == '..'))
				continue;
 
			if (is_file ($path.$res)) 
			{
				$exp = explode ('/', $path);
				array_pop ($exp);
 
				$len = count ($exp);
 
				for ($i = 0; $i < $len; ++$i) 
					$exp[$i] .= '/';
 
				$this->array_dim ($array, $exp, $res);
			}	
 
			elseif (is_dir($path.$res.'/')) 
				$this->folder_recursive($array, $path.$res.'/');
		}
 
		@closedir($dir);
 
		return TRUE;
	}
 
	function array_dim (&$array, $dim, $value, $key = NULL)
	{
		if (!is_array ($dim)) 
			return FALSE;
 
		$string = '$array';
 
		foreach ($dim as $key_ => $value_) $string .= '[\''.$this->quoteslashes ($value_).'\']';
 
		$string .= ($key === NULL) ? '[]' : '[\''.$this->quoteslashes ($key).'\']';
 
		$string .= ' = \''.$this->quoteslashes ($value).'\';';
 
		if ($this->is_err ($string))
			return FALSE;	
		else
			eval ($string);
 
		return TRUE;
	}
 
	function quoteslashes ($string)
	{
		return str_replace ('\'', '\\\'', $string);	
	}
 
	function is_err ($expr)
	{
		$err = @ini_get ('error_reporting');
		error_reporting (E_ALL);
 
		ob_start ();
		eval ($expr);
		$str = ob_get_contents ();
		ob_end_clean ();
 
		error_reporting ($err);
 
		return (strlen($str) != 0);
	}
}
Pour l'utiliser

Code :
$a = array ();
 
$obj = new folder_recursive ($a, './');
 
echo '<pre>', print_r ($a), '</pre>';
Dozer est déconnecté   Envoyer un message privé Réponse avec citation
Vieux 29/09/2005, 11h36   #9 (permalink)
Futur Membre du Club
 
Date d'inscription: juillet 2004
Messages: 34
Par défaut

Proposer de récupérer une page web en PDF

Nécéssaire :
htmldoc d'installé sur un serveur unix/linux

A remplir :
Code :
 
$racine = "chemin par rapport à la racine du site";
$chemin = "de l'image du logo PDF";
 
La fonction à intégrer:
Code :
 
function GenererPDF($contenu){
	global $racine;
	global $skin;
 
	// Formulaire de demande de PDF
	if (empty($_POST['PDF'])){
		echo $contenu; 
		echo "  <form action=\"".$_SERVER['PHP_SELF']."\" name=\"Genpdf\" method=\"POST\">
		        <input type=\"submit\" name=\"PDF\" value=\"PDF\" align=\"left\">
			</form>";
	}else{ 
	
		// Vérification/création du cache
		// mise en place d'un accès total à ce repertoire
		if (!file_exists($_SERVER['DOCUMENT_ROOT']."/cache"))
		{
			exec("mkdir ".$_SERVER['DOCUMENT_ROOT']."/cache | chmod 777 ".$_SERVER['DOCUMENT_ROOT']."/cache");
			echo "Le dossier de Cache a bien été créé";
		}
		// Si les droits sur le dossier ont changé on tente de les remettre (www-data doit être proprio du dossier)
		if (substr(sprintf('%o', fileperms($_SERVER['DOCUMENT_ROOT'].'/cache')), -4) !== "777")
		{
			$anciendroit = substr(sprintf('%o', fileperms($_SERVER['DOCUMENT_ROOT'].'/cache')), -4);
			exec("chmod 777 ".$_SERVER['DOCUMENT_ROOT']."/cache");
			echo "Les droits sur le dossier cache ont changés (mis à ".$anciendroit."), ils ont donc été remis à 777";
		}
		
		// Création d'un nom de fichier 
		$nomfichier = ereg_replace(".php","",$_SERVER['PHP_SELF']);
		$nomfichier = substr_replace($nomfichier,"",0,1);
		$nomfichier = ereg_replace("/","_",$nomfichier);
		$nomfichier = ereg_replace(" ","",$nomfichier);
		$nomfichier = strtr($nomfichier,"àáâãäåçèéêëìíîïñòóôõöøùúûüý","aaaaaaceeeeiiiinoooooouuuuy");
 
	
		// Nettoyage de printemps
		if (file_exists($_SERVER['DOCUMENT_ROOT']."/cache/".$nomfichier.".txt"))
		{
			exec("rm ".$_SERVER['DOCUMENT_ROOT']."/cache/".$nomfichier.".txt"); 
		}
		if (file_exists($_SERVER['DOCUMENT_ROOT']."/cache/".$nomfichier.".pdf"))
		{
			exec("rm ".$_SERVER['DOCUMENT_ROOT']."/cache/".$nomfichier.".pdf"); 
		}
	
		// Copie du code HTML -> /cache
		$fp = file($_SERVER['DOCUMENT_ROOT']."/cache/".$nomfichier.".txt");
		if ( $fp = fopen($_SERVER['DOCUMENT_ROOT']."/cache/".$nomfichier.".txt", "w+") )
		{
			fwrite( $fp, $contenu); 
		}else{
			echo "Le PDF n'a pas pu être généré : Erreur à la création du fichier temporaire";
		}
		fclose($fp);            
		sleep(1);
		
              // Appel de HTMLDOC pour generer le PDF
               $sortie = exec('htmldoc -t pdf --quiet  --jpeg=90  --webpage '.$_SERVER['DOCUMENT_ROOT'].'cache/'.$nomfichier.'.txt -f '.$_SERVER['DOCUMENT_ROOT'].'cache/'.$nomfichier.'.pdf',$tableau,$retour);
   
               if($retour == 0) 
		{
			echo "\n Veuillez patienter génération de votre PDF.....";
			sleep(2);
			echo "\n <br><br><a href='".$racine."cache/".$nomfichier.".pdf'>";
			echo "	<img src='".$skin."' alt='Télécharger ".$nomfichier.".pdf' border='0' width='40'>";
			echo "	Télécharger ".$nomfichier.".pdf</a>";
 
			// On supprime le fichier temporaire .txt
			if (file_exists($_SERVER['DOCUMENT_ROOT']."/cache/".$nomfichier.".txt"))
			{
				exec("rm ".$_SERVER['DOCUMENT_ROOT']."/cache/".$nomfichier.".txt"); 
			}
		}else{
	 		echo "Le PDF n'a pas pu être généré: Erreur pendant la création du PDF";
		}
	}
}
 
dans les pages web où vous voulez créer du PDF vous encadrer le code PHP de ces balises
Code :
 
 ob_start();
 
et par
Code :
 
 $contenu = ob_get_contents();
ob_end_clean();
 
et vous mettez ensuite ceci où vous voulez que le bouton générer un PDF apparaisse
Code :
GenererPDF($contenu);
saint-pere est déconnecté   Envoyer un message privé Réponse avec citation
Vieux 16/11/2005, 10h12   #10 (permalink)
Membre habitué
 
Avatar de thanathz
 
Date d'inscription: mars 2002
Messages: 152
Envoyer un message via ICQ à thanathz Envoyer un message via AIM à thanathz Envoyer un message via Yahoo à thanathz
Par défaut

Voici une class générant des graphiques.

Ca se trouve ici:
http://nbacenter.free.fr/tools/grafik.zip

avec une page de téléchargement des divers doc (comme par exemple les webservices et SOAP pour PHP) c'est sur http://nbacenter.free.fr/tools

et on peut pour l'instant générer trois types de graphiques: les courbes et les camemberts et histogrammes.

Le seul format supporté pour l'instant est le png et gif et jpg.

reste encore un petit bug (qui n'existe pas en local sur l'histogramme...)

Passage à la version 1.0a. Correction de nombreux bugs.
Prochaine étape, le mixage des graphiques (notament: histogramme et courbes)

exemple de courbes:



exemple de camemberts:


Et les histogrammes:


Je modifierais au fur et à mesure des évolutions ce post.

Dernière modification par Kerod ; 15/09/2006 à 00h13. Motif: Ajouté page Sources
thanathz est déconnecté   Envoyer un message privé Réponse avec citation
Vieux 26/11/2005, 14h17   #11 (permalink)
Membre Expert
 
Date d'inscription: juillet 2004
Messages: 1 046
Par défaut

SECONDE CLASSE DE PAGINATION

Salut,

Suite à la classe de pagination de Moloch je poste la mienne qui pour le coup se détache des requetes et est plus simple à porte sur les projets ( efin je pense).

A vous de juger de toute facon

Code :
 
<?
class Pagination{
 
    var $URL;                            // URL du lien
    var $NomVar;                        // Nom de la variable indiquant la page courante
    var $Nombre;                        // Nombre de pages à afficher
    var $Class;                            // Class à utiliser pour les liens
    var $Total;                            // Nombre d'éléments total (les éléments qui sont paginés)
    var $SelectedClass;                // Class à utiliser pour la page actuellement selectionnée
    var $SelectedPage;                // Numéro de la page selectionnée
    var $CaractereDespacement;        // Définit le cractères qui sépares chaque page
    var $ShowPreview;                    // Définit si précédents doit TOUJOURS être afficher
    var $TextPreview;                    // Texte à afficher pour le bouton précédent
    var $TextNext;                        // Texte à afficher pour le bouton suivant
    var $TextPrevGroup;                // Texte à afficher pour le bouton groupe précédent
    var $TextNextGroup;                // Texte à afficher pour le bouton groupe suivant
    
    /* PRIVATE :: inutile de la modifier */
    var $Debut;                            // Page à laquelle débute l'actuel pagination
 
    function __construct(  )
    {
        $this->URL                            = "";
        $this->NomVar                        = "";
        $this->Debut                        = "";
        $this->Nombre                        = "";
        $this->Class                        = "";
        $this->Total                        = 0;
        $this->SelectedClass                = "";
        $this->SelectedPage                = 0;
        $this->Reponse                        = "";
        $this->ShowPreviewAndNext        = true;
        $this->CaractereDespacement     = "";
        $this->TextPreview                 = "&lt;";
        $this->TextNext                     = "&gt;";
        $this->TextPrevGroup             = "&lt;&lt;";
        $this->TextNextGroup             = "&gt;&gt;";
    }
 
    function Pagine(  )
    {
        $reponse                 = "";
        $this->SelectedPage     = $this->SelectedPage     == "" ? 0 : intval($this->SelectedPage);
        $this->Nombre             = $this->Nombre             == "" ? 0 : intval($this->Nombre);
        $this->Total             = ceil ($this->Total);
 
        if($this->Total < 1 )
        {
            return false;
        }
        
        
        $this->DefineInterval( );
        
        if($this->Debut < $this->Nombre )
        {
            $this->Debut = 0;
        }
        
        if($this->Debut >= $this->Nombre )
        {
            $reponse = "<a href=\"".$this->URL."&".$this->NomVar."=".($this->Debut-$this->Nombre)."\" class=\"".$this->Class."\" >".$this->TextPrevGroup."</a>&nbsp;&nbsp;";
        }
        elseif ( $this->ShowPreviewAndNext == true) 
        {
            $reponse = "<a class=\"".$this->SelectedClass."\" >".$this->TextPrevGroup."</a>&nbsp;&nbsp;";
        }
        
        if( ($this->SelectedPage-$this->Debut) > 0 )
        {
            //$url = str_replace(".html" , "-".$this->NomVar."-".($this->SelectedPage-1).".html" , $this->URL);
            $reponse .= "<a href=\"".$this->URL."&".$this->NomVar."=".($this->SelectedPage-1)."\" class=\"".$this->Class."\" >".$this->TextPreview."</a>&nbsp;&nbsp;";
        }
        else
        {
            $reponse .= "<a class=\"".$this->SelectedClass."\" >".$this->TextPreview."</a>&nbsp;&nbsp;";
        }
        
        if( ($this->Nombre + $this->Debut) > $this->Total )
        {
            $this->Nombre = $this->Total - $this->Debut;
        }
        
        for($ii=0,$i=$this->Debut; $i < $this->Debut+$this->Nombre; $i++)
        {    
            $ii = $i > 8 ? $i+1 : "0".($i+1);
            if( $i == $this->SelectedPage )
            {
                $reponse .= "<a class=\"".$this->SelectedClass."\" >".$ii."</a>".$this->CaractereDespacement;
            }
            else
            {
                //$url = str_replace(".html" , "-".$this->NomVar."-".$i.".html" , $this->URL);
                $reponse .= "<a href=\"".$this->URL."&".$this->NomVar."=".$i."\" class=\"".$this->Class."\" >".$ii."</a>".$this->CaractereDespacement;
            }
        }
 
        if( ($this->Debut+$this->Nombre)-$this->SelectedPage > 1 )
        {
            $reponse = substr ( $reponse, 0 , ( strlen($reponse) - strlen($this->CaractereDespacement) )  );
            //$url = str_replace(".html" , "-".$this->NomVar."-".($this->SelectedPage+1).".html" , $this->URL);
            $reponse .= "&nbsp;<a href=\"".$this->URL."&".$this->NomVar."=".($this->SelectedPage+1)."\" class=\"".$this->Class."\" >".$this->TextNext."</a>&nbsp;";
        }
        else
        {
            $reponse = substr ( $reponse, 0 , ( strlen($reponse) - strlen($this->CaractereDespacement) )  );
            $reponse .= "&nbsp;<a class=\"".$this->SelectedClass."\" >".$this->TextNext."</a>&nbsp;";
        }
        
        if( ($this->Debut + $this->Nombre) < ( $this->Total ) )
        {
            //$url = str_replace(".html" , "-".$this->NomVar."-".($this->Debut+$this->Nombre).".html" , $this->URL);
            $reponse .= "&nbsp;<a href=\"".$this->URL."&".$this->NomVar."=".($this->Debut+$this->Nombre)."\" class=\"".$this->Class."\" >".$this->TextNextGroup."</a>";
        }
        elseif ( $this->ShowPreviewAndNext == true) 
        {
            $reponse .= "&nbsp;<a class=\"".$this->SelectedClass."\" >".$this->TextNextGroup."</a>";
        }
        else
        {
            $reponse = substr ( $reponse, 0 , ( strlen($reponse) - strlen($this->CaractereDespacement) )  );
        }
        
        if($reponse != "")
        {
            $this->Reponse = $reponse;
            return true;
        }
        
        return false;
    }
    
    function DefineInterval( )
    {
        $this->Debut = $this->Nombre * floor ($this->SelectedPage / $this->Nombre ) ;
    }
    
}
 
?>
<? 
$_GET["debut"] = isset($_GET["debut"])?$_GET["debut"]:0;
$Pages                             = new Pagination();
$Pages->URL                     = "index.php?var=1";
$Pages->NomVar                    = "debut";
$Pages->Nombre                    = 5;
$Pages->Class                    = "LienPages";
$Pages->SelectedClass            = "LienPagesSelected";
$Pages->SelectedPage            = $_GET["debut"];
$Pages->Total                    = 150/15;
$Pages->CaractereDespacement    = "&nbsp;";
/* A vous de le changer ! */
$Pages->TextPreview    = "TextPreview";
$Pages->TextNext    = "TextNext";
$Pages->TextPrevGroup    = "TextPrevGroup";
$Pages->TextNextGroup    = "TextNextGroup";
if($Pages->Pagine() == true)
{
echo $Pages->Reponse;
} 
else
{
echo "pas de pages ";
}
?>
}
?>
Petite not tout de même, le script présuppose que vous avez déja des variables dans l'url, c a d qu'il construit l'url en supposant que l'url est de la forme http://sdflkjsdlfjds.com?var=valeur

Il rajoute à la suite sa variable sous la forme &debut=15.

Fin bref vaut mieux le tester pour comprendre la limite à ce sujet.

Bye tlm

epox

Dernière modification par Yogui ; 30/04/2006 à 14h01.
ePoX est déconnecté   Envoyer un message privé Réponse avec citation
Vieux 28/11/2005, 09h40   #12 (permalink)
Nouveau membre du Club
 
Date d'inscription: janvier 2005
Messages: 63
Par défaut

Toujours dans les barre de navigation, laissez moi vous présenter la mienne que je trouvre vraiment plus simple :

elle permat de rechercher des informations dans une bases de données en limitant l'affichage du nombre de résultat de la page à dix.


Code :
 <?php
//si un numero de page est envoyé on le récupère et on met à jour les limites d'affichage
if(isset($_GET['page']))
{
    $Page = $_GET['page']-1;
    if($Page == 0)
    {  
        $debut = 0;
        $fin = 10;
    }
    else
    {
        $debut = ($Page * 10);
        $fin = $debut + 9;
    }
}
else
{
    //sinon ça correspond aux 10 premières lignes de la recherche
    $debut = 0;
    $fin = 10;
}
//nombre de résultats par page
$maxRows_RechercheClient = 10;
//requete qui selectionne les clients dont le nom correspond aux données saisies
$query_RechercheClient = "SELECT NumClient,NomClient  FROM WHERE nomccli LIKE '%$recherche%' Order by NumClient LIMIT $debut,$fin ";
$RechercheClient = mysql_query($query_limit_RechercheClient) or die(mysql_error());
$row_RechercheClient = mysql_fetch_assoc($RechercheClient);
 
//determine le nombre total de pages
if (isset($_GET['totalRows_RechercheClient'])) 
{
     $totalRows_RechercheClient = $_GET['totalRows_RechercheClient'];
} 
else 
{
$all_RechercheClient = mysql_query($query_RechercheClient);
    $totalRows_RechercheClient = mysql_num_rows($all_RechercheClient);
}
$totalPages_RechercheClient = ceil($totalRows_RechercheClient/$maxRows_RechercheClient); 
$i=0;
// ---------- Afficher le tableau de résultat--------    
 
    
//si j'ai au moins une page de résultats            
if($totalPages_RechercheClient >1)
{    
for ($j =1; $j<= $totalPages_RechercheClient; $j++) 
{  
    // Affiche la barre de navigation
    echo "<a href = '".$cible."?page=$j&recherche=".$recherche."'>$j</a> ";
} 
}

Dernière modification par Eric Berger ; 28/06/2006 à 00h19.
dinde est déconnecté   Envoyer un message privé Réponse avec citation
Vieux 30/11/2005, 00h46   #13 (permalink)
Membre Expert
 
Date d'inscription: juillet 2004
Messages: 1 046
Par défaut

Salut,

je trouvais cette petite classe de benchmark tellement pratique que je me la suis réadaptée vite fait pour mes projets.

C'est pas mieux, ni différent, c'est juste plus maléable au niveau de la sortie.

bref vu que j'ai tout pompé je vais pas me priver de la remettre pour qui veut.

en tout cas bien vu genova et thanathz

Bye

Code :
 
<? 
class Benchmark 
{ 
   
   private $Marks; 				// Contient les différents temps pour les étapes 
   private $TimeEnd; 			// Temps final 
   private $TimeStart; 			// Temps de départ
   private $TotalChanged;		// Indique si le total doit etre reclaculé
   private $Total_;				// Indique si le total doit etre reclaculé
 
   /* 
   ** Constructeur de la classe bench. 
   ** Initialise le temps de départ. 
   */ 
   public function __construct() 
   { 
      $this->TimeStart 		= 0; 
      $this->TimeEnd 		= 0; 
	  $this->Total_			= 0;
      $this->Marks 			= array(); 
      $this->TotalChanged 	= false; 
	  
      $this->TimeStart 	= microtime(true); 
   }
 
   /* 
   ** Créé un marqueur qui retient le temps écoulé. 
   */ 
   public function addMark( $Nom , $Commentaire )
   {
		$Mark = new Mark( $Nom , $Commentaire );
		array_push($this->Marks , $Mark);
		$this->TotalChanged 	= true; 
   } 
   
   
   public function StopLastAddedMark( )
   {
      $Mark = $this->Marks[count($this->Marks)-1]->Stop();
   }
   
   public function __get( $prop )
   {
   		switch( $prop )
		{
			case "Total":
				if( $this->TotalChanged )
				{
					$this->Total_ = 0;
					for($i=0 , $ii=count($this->Marks);$i<$ii; $i++)
					{
						$this->Total_ += $this->Marks[$i]->Duree;
					}
					$this->TotalChanged = false;
					return $this->Total_;
				}
				else
				{
					return $this->Total_;
				}
			break;
			case "Duree":
				$this->TimeEnd = $this->TimeEnd == 0 ? microtime(true) : $this->TimeEnd;
				return $this->TimeEnd-$this->TimeStart;
			break;
			case "TimeStarted":
				return date("H:i:s",$this->TimeStart);
			break;
			case "TimeEnded":
				return date("H:i:s",$this->TimeEnd);
			break;
			case "Items":
				return $this->Marks;
			break;
		}
   }
   
   public function Stop ( )
   {
   		$this->TimeEnd = microtime(true); 
   }
}
 
class Mark
{
	public $TimeStart;
	public $TimeEnd;
	public $Nom;
	public $Commentaires;
	
	public function __construct( $Nom , $Commentaire )
	{
		$this->TimeStart 		= 0;
		$this->TimeEnd 			= 0;
		$this->Nom 				= $Nom;
		$this->Commentaires 	= $Commentaire;
		
		$this->TimeStart 		= microtime(true); 
	}
	
	public function __get( $prop )
	{
		switch( $prop )
		{
			case "Duree":
            $this->TimeEnd = $this->TimeEnd == 0 ? microtime(true) : $this->TimeEnd;
            return $this->TimeEnd-$this->TimeStart < 0 ? 0 : $this->TimeEnd-$this->TimeStart;
			break;
			case "TimeStarted":
				return date("H:i:s",$this->TimeStart);
			break;
			case "TimeEnded":
				return date("H:i:s",$this->TimeEnd);
			break;
		}
	}
   
   public function Stop ( )
   {
   		$this->TimeEnd = microtime(true); 
   }
}
 
 
//*****************************************************************************************
// APPLI TEST
//*****************************************************************************************
$Yop = new Benchmark();
usleep(2000000);
$Yop->addMark( "+2" , "Stopper à +8" );
usleep(2000000);
$Yop->addMark( "+4" , "Stopper à +10" );
usleep(2000000);
$Yop->addMark( "+6" , "Stopper à +12" );
usleep(2000000);
$Yop->Items[0]->Stop();
usleep(2000000);
$Yop->Items[1]->Stop();
usleep(2000000);
$Yop->Items[2]->Stop();
usleep(2000000);
$Yop->Stop();
 
echo "<div style=\"font-family:Arial;\">";
echo "Debuter à ".$Yop->TimeStarted;
echo "<br/>";
	for( $i =0; $i < count($Yop->Items); $i++ )
	{
		echo "&nbsp;&nbsp;&nbsp;&nbsp; Nom : ";
		echo "<strong>".$Yop->Items[$i]->Nom."</strong>";
		echo "<br/>";
		echo "&nbsp;&nbsp;&nbsp;&nbsp; Commentaires :";
		echo "".$Yop->Items[$i]->Commentaires."";
		echo "<br/>";
		echo "&nbsp;&nbsp;&nbsp;&nbsp; Debuter à ";
		echo "".$Yop->Items[$i]->TimeStarted."";
		echo "<br/>";
		echo "&nbsp;&nbsp;&nbsp;&nbsp; Fini à ";
		echo "".$Yop->Items[$i]->TimeEnded."";
		echo "<br/>";
		echo "&nbsp;&nbsp;&nbsp;&nbsp; A durée ";
		echo "".$Yop->Items[$i]->Duree." secondes";
		echo "<br/>";
		echo "&nbsp;&nbsp;&nbsp;&nbsp; Pourcentage du total ";
		echo "".round(($Yop->Items[$i]->Duree/$Yop->Total)*100)." % ";
		echo "<br/>";
		echo "&nbsp;&nbsp;&nbsp;&nbsp; ---------------------------------------------------------------------------------";
		echo "<br/>";
	}
echo "Fini à ".$Yop->TimeEnded;
echo "<br/>";
echo "A durée : ".$Yop->Duree." secondes";
echo "<br/>";
echo "</div>";
?> 
 
ePoX est déconnecté   Envoyer un message privé Réponse avec citation
Vieux 07/12/2005, 10h43   #14 (permalink)
Membre à l'essai
 
Date d'inscription: novembre 2005
Messages: 40
Par défaut

Nom de la classe : mysqlHelper
Configuration requise : PHP 5 et mySQL >= 4.0.25
Propriétés :
  • Connection/Deconnection à une base mysql
  • Récupération liste des bases d'une serveur, des tables d'une base, des champs et index d'une table
  • Permet d'exporter une base de donnée sans l'utilitaire mysqldump.exe
  • Exporte la strucutre complète d'une base sous format XML
  • Permet de répliquer une base de donnée maître vers N bases de donnée esclaves
Réplication : J'ai créé cette fonction car je suis en hébergement mutualisé sans accès aux fonctions de réplication de mySQL ni aux fichiers de logs de mySQL.
Pour le moment, elle permet de répliquer les :
  • Ajout/Modification/suppression de tables
  • Ajout/Modification/suppression de champs
  • Ajout/Modification/suppression d'index
  • Contenus de certaines tables (paramétrées dans un fichier de config)
Remarques : Cette version ne tient pas compte des nouveautés des mySQL 5 (je n'ai pas accès à cette version pour le moment).
Contenu du fichier :
  • La classe
  • Un exemple de fichier de config pour al réplication
  • Un fichier d'exemples
Lien:mysqlHelper

Dernière modification par Kerod ; 15/09/2006 à 00h15. Motif: Ajouté page Sources
ankou2005 est déconnecté   Envoyer un message privé Réponse avec citation
Vieux 19/12/2005, 13h30   #15 (permalink)
Inscrit(e)
 
Avatar de Caerbannog
 
Date d'inscription: novembre 2004
Messages: 204
Par défaut

Remplacement de glob()
Free (comme d'autre hébergeurs) a désactivé la fonction Glob() à cause d'une faille. En plus elle retourne NULL et on peut pas en faire une du même nom !
Voici comment l'émuler :
Code :
<?
// (C) Caerbannog 2005
if(glob("doYouExist?") == NULL) {
     function free_glob($path) {
          $result = Array();
          $index = 0;
          preg_match("#^(.*/)?([^/]*)$#", $path, $matches);
          list(, $dir, $path) = $matches;
          $path = "#" . str_replace(Array("\\", ".", "[", "]", "?", 
                                          "+", "(", ")", "#", "*"),
                                    Array("\\\\", "\\.", "\\[", "\\]", "\\?",
                                          "\\+", "\\(", "\\)", "\\#", "([^/]*)"),
                                    $path) . "#";
          if($dir == '')
               $handle = opendir('.');
          else
               $handle = opendir($dir);
          while($file = readdir($handle)) {
               if($file == '..' || $file == '.')
                    continue;
               if(preg_match($path, $file)) {
                    if(is_file($dir . $file)) {
                         $result[$index] = $dir . $file;
                         $index++;
                    }
               }
          }
          closedir($handle);
          return $result;
     }
}
?>
Plus de fonctions de Free émulées.
Caerbannog est déconnecté   Envoyer un message privé Réponse avec citation
NEWS PHPFAQ PHPCOURS PHPSOURCES PHPLIVRES PHPSCRIPTS PHPOUTILS PHPCOMPARATIFSZend Framework

Réponse

Précédent   Forum des professionnels en informatique > PHP > Langage > Contribuez



Outils de la discussion

Règles de messages
Vous ne pouvez pas créer de nouvelles discussions
Vous ne pouvez pas envoyer des réponses
Vous ne pouvez pas envoyer des pièces jointes
Vous ne pouvez pas modifier vos messages

Les balises BB sont activées : oui
Les smileys sont activés : oui
La balise [IMG] est activée : oui
Le code HTML peut être employé : non
Trackbacks are non
Pingbacks are non
Refbacks are non

Navigation rapide


Fuseau horaire GMT +2. Il est actuellement 13h17.


Vos questions techniques : forum d'entraide PHP - Publiez vos articles, tutoriels et cours
et rejoignez-nous dans l'équipe de rédaction du club d'entraide des développeurs francophones
Nous contacter - Hébergement - Participez - Copyright © 2000-2009 www.developpez.com - Legal informations.