security_check(); if ($resultat_session == 'c') { header("Location: ../utilisateurs/mon_compte.php?change_mdp=yes"); die(); } else if ($resultat_session == '0') { header("Location: ../logout.php?auto=1"); die(); } $sql="SELECT 1=1 FROM droits WHERE id='/init_csv/export_tables.php';"; $test=mysqli_query($GLOBALS["mysqli"], $sql); if(mysqli_num_rows($test)==0) { $sql="INSERT INTO droits SET id='/init_csv/export_tables.php', administrateur='V', professeur='F', cpe='F', scolarite='F', eleve='F', responsable='F', secours='F', autre='F', description='Initialisation CSV: Export tables', statut='';"; $insert=mysqli_query($GLOBALS["mysqli"], $sql); } if (!checkAccess()) { header("Location: ../logout.php?auto=1"); die(); } //**************** EN-TETE ***************** $titre_page = "Export des tables"; require_once("../lib/header.inc.php"); //**************** FIN EN-TETE ***************** ?>
Vous pouvez exporter le contenu actuel des tables au format CSV.Les fichiers ainsi obtenus peuvent permettre de préparer une nouvelle année, si peu de modifications sont requises.
\n"; echo "\n"; require("../lib/footer.inc.php"); die(); } if($_SESSION['user_temp_directory']!='y') { echo "ERREUR : Le dossier temporaire ne semble pas accessible.
Les fichiers CSV ne pourront pas être générés.
Nettoyage du dossier temporaire $dirname.
\n"; $tab_fich=array("g_eleves.csv", "g_eleves_classes.csv", "g_eleves_options.csv", "g_responsables.csv", "g_disciplines.csv", "g_professeurs.csv", "g_prof_disc_classes.csv"); for($i=0;$iGénération des fichiers CSV au format 'init_csv' :
\n"; // Nom ; Prénom ; Date de naissance ; n° identifiant interne (étab) ; n° identifiant national ; Code établissement précédent ; Doublement (OUI | NON) ; Régime (INTERN | EXTERN | IN.EX. | DP DAN) ; Sexe (F ou M) $sql="SELECT * FROM eleves e, j_eleves_regime jer WHERE jer.login=e.login ORDER BY e.nom, e.prenom;"; $res=mysqli_query($GLOBALS["mysqli"], $sql); if(mysqli_num_rows($res)==0) { echo "Aucun élève n'a été trouvé.
\n"; } else { $lignes=""; while($lig=mysqli_fetch_object($res)) { $lignes.="$lig->nom;$lig->prenom;".formate_date($lig->naissance).";$lig->elenoet;$lig->no_gep;"; $sql="SELECT * FROM j_eleves_etablissements WHERE id_eleve='$lig->elenoet';"; $res2=mysqli_query($GLOBALS["mysqli"], $sql); if(mysqli_num_rows($res2)>0) { $lig2=mysqli_fetch_object($res2); $lignes.=$lig2->id_etablissement; } $lignes.=";"; if($lig->doublant=='O') {$lignes.="OUI;";} else {$lignes.="NON;";} if($lig->regime=='d/p') { $lignes.="DP DAN"; } elseif($lig->regime=='ext.') { $lignes.="EXTERN"; } elseif($lig->regime=='i-e') { $lignes.="IN.EX."; } elseif($lig->regime=='int.') { $lignes.="INTERN"; } $lignes.=";"; $lignes.="$lig->sexe;\r\n"; } $fich=fopen("../temp/".$dirname."/g_eleves.csv","w+"); if(!$fich) { echo "ERREUR : Le fichier g_eleves.csv n'a pas pu être généré dans le dossier temporaire.
\n"; } else { fwrite($fich,$lignes); fclose($fich); } echo "g_eleves.csvAucun responsable n'a été trouvé.
\n"; } else { $lignes=""; while($lig=mysqli_fetch_object($res)) { $lignes.="$lig->elenoet;$lig->nom;$lig->prenom;$lig->civilite;$lig->adr1;$lig->adr2;$lig->cp;$lig->adr1;$lig->commune;"; $lignes.="\r\n"; } $fich=fopen("../temp/".$dirname."/g_responsables.csv","w+"); if(!$fich) { echo "ERREUR : Le fichier g_responsables.csv n'a pas pu être généré dans le dossier temporaire.
\n"; } else { fwrite($fich,$lignes); fclose($fich); } echo "g_responsables.csvAucune matière n'a été trouvée.
\n"; } else { $lignes=""; while($lig=mysqli_fetch_object($res)) { $lignes.="$lig->matiere;$lig->nom_complet;"; $lignes.="\r\n"; } $fich=fopen("../temp/".$dirname."/g_disciplines.csv","w+"); if(!$fich) { echo "ERREUR : Le fichier g_disciplines.csv n'a pas pu être généré dans le dossier temporaire.
\n"; } else { fwrite($fich,$lignes); fclose($fich); } echo "g_disciplines.csvAucun professeur n'a été trouvé.
\n"; } else { $lignes=""; while($lig=mysqli_fetch_object($res)) { $lignes.="$lig->nom;$lig->prenom;$lig->civilite;$lig->email;"; $lignes.="\r\n"; } $fich=fopen("../temp/".$dirname."/g_professeurs.csv","w+"); if(!$fich) { echo "ERREUR : Le fichier g_professeurs.csv n'a pas pu être généré dans le dossier temporaire.
\n"; } else { fwrite($fich,$lignes); fclose($fich); } echo "g_professeurs.csvAucune association élève/classe n'a été trouvée.
\n"; } else { $lignes=""; while($lig=mysqli_fetch_object($res)) { $tab_ele_clas[$lig->elenoet]=$lig->classe; $lignes.="$lig->elenoet;$lig->classe;"; $lignes.="\r\n"; } $fich=fopen("../temp/".$dirname."/g_eleves_classes.csv","w+"); if(!$fich) { echo "ERREUR : Le fichier g_eleves_classes.csv n'a pas pu être généré dans le dossier temporaire.
\n"; } else { fwrite($fich,$lignes); fclose($fich); } echo "g_eleves_classes.csvAucun professeur n'a été trouvé.
\n"; } else { $lignes=""; while($lig_prof=mysqli_fetch_object($res_prof)) { //$sql="SELECT jgm.id_matiere, FROM j_groupes_professeurs jgp, j_groupes_classes jgc, j_groupes_matieres jgm WHERE jgm.id_groupe=jgp.id_groupe AND jgc.id_groupe=jgp.id_groupe AND jgp.login='$lig->login' ORDER BY jgc.id_classe, jgm.id_matiere;"; $sql="SELECT jgm.id_matiere, jgm.id_groupe FROM j_groupes_professeurs jgp, j_groupes_matieres jgm WHERE jgm.id_groupe=jgp.id_groupe AND jgp.login='$lig_prof->login' ORDER BY jgm.id_matiere;"; $res_grp=mysqli_query($GLOBALS["mysqli"], $sql); if(mysqli_num_rows($res_grp)>0) { while($lig_grp=mysqli_fetch_object($res_grp)) { $sql="SELECT DISTINCT c.id, c.classe FROM j_groupes_classes jgc, classes c WHERE jgc.id_groupe='$lig_grp->id_groupe' AND jgc.id_classe=c.id ORDER BY c.classe;"; $res_clas=mysqli_query($GLOBALS["mysqli"], $sql); if(mysqli_num_rows($res_clas)>0) { $classes=""; $cpt_classes=0; $current_id_classe=""; $first_classe=""; while($lig_clas=mysqli_fetch_object($res_clas)) { if($cpt_classes>0) { $classes.="!"; $tab_clas_opt["$lig_clas->classe"][]=$lig_grp->id_matiere; } else { $first_classe=$lig_clas->classe; } $classes.=$lig_clas->classe; $current_id_classe=$lig_clas->id; $cpt_classes++; } $lignes.="$lig_prof->login;$lig_grp->id_matiere;$classes;"; // Est-ce un cours général? ou une option? if($cpt_classes>1) { $lignes.="OPT;"; $tab_clas_opt["$first_classe"][]=$lig_grp->id_matiere; } else { // Tous les élèves de la classe suivent-ils l'enseignement? $sql="SELECT 1=1 FROM j_eleves_groupes WHERE id_groupe='$lig_grp->id_groupe';"; $test1=mysqli_query($GLOBALS["mysqli"], $sql); //$sql="SELECT 1=1 FROM j_eleves_classes WHERE id_classe='$lig_clas->id';"; $sql="SELECT 1=1 FROM j_eleves_classes WHERE id_classe='$current_id_classe';"; $test2=mysqli_query($GLOBALS["mysqli"], $sql); if(mysqli_num_rows($test1)==mysqli_num_rows($test2)) { $lignes.="CG;"; } else { $lignes.="OPT;"; $tab_clas_opt["$first_classe"][]=$lig_grp->id_matiere; } } $lignes.="\r\n"; } } } } $fich=fopen("../temp/".$dirname."/g_prof_disc_classes.csv","w+"); if(!$fich) { echo "ERREUR : Le fichier g_prof_disc_classes.csv n'a pas pu être généré dans le dossier temporaire.
\n"; } else { fwrite($fich,$lignes); fclose($fich); } echo "g_prof_disc_classes.csvAucun élève n'a été trouvé.
\n"; } else { $lignes=""; while($lig_ele=mysqli_fetch_object($res_ele)) { $sql="SELECT DISTINCT jgm.id_matiere FROM j_eleves_groupes jeg, j_groupes_matieres jgm WHERE jeg.login='$lig_ele->login' AND jeg.id_groupe=jgm.id_groupe ORDER BY id_matiere;"; $res_matiere=mysqli_query($GLOBALS["mysqli"], $sql); if(mysqli_num_rows($res_matiere)>0) { $matieres=""; $nb_mat=0; while($lig_mat=mysqli_fetch_object($res_matiere)) { $current_elenoet=$lig_ele->elenoet; if(isset($tab_clas_opt["$tab_ele_clas[$current_elenoet]"])) { if(in_array($lig_mat->id_matiere,$tab_clas_opt["$tab_ele_clas[$current_elenoet]"])) { if($nb_mat>0) { $matieres.="!"; } $matieres.=$lig_mat->id_matiere; $nb_mat++; } } } if($nb_mat>0) { $lignes.="$lig_ele->elenoet;$matieres;"; $lignes.="\r\n"; } } } $fich=fopen("../temp/".$dirname."/g_eleves_options.csv","w+"); if(!$fich) { echo "ERREUR : Le fichier g_eleves_options.csv n'a pas pu être généré dans le dossier temporaire.
\n"; } else { fwrite($fich,$lignes); fclose($fich); } echo "g_eleves_options.csvLes fichiers ont été générés dans un dossier temporaire.
Après récupération des fichiers, vous devriez faire le ménage dans ce dossier temporaire.
Supprimer les fichiers générés