Importer tables en CSV dans phpmyadmin

lol -  
 kalamit -
Bonjour,
J'ai enregistré le resultset d'une table en *.CSV que j'ai récupéré sur un server sur le net, et je voudrais l'importer en table dans ma base existante sur phpmyadmin.
Qqun peut-il me dire comment m'y prendre ?
En vous remerciant
A voir également:

7 réponses

kuslargibi
 
// ****************************************************************** *
// ******Lire un csv et l'importer dans la base de donnée *
// ******2 fichiers nécessaires : formulaire.php et ajouter.php *
// *********l'un pour choisir le fichier csv et l'autre pour *
// ***************enregistrer dans la bdd *
**** le fichier csv doit etre du type ci dessous *
*** link,email *
*** www.mafonction.com,axel@tueslemeilleur.com *
*** www.csvfacile.com,csv@insert.com *
///************************************************************ *********




//formulaire.php
<form action="ajouter.php" method="post" enctype="multipart/form-data" name="form1">


<p><input type="file" name="file" /></p>

<input type="submit" name="Submit" value="Submit">
</form>


________________________________________________






//ajouter.php


//lire un csv et ajouter le couple email,url dans la base de donnee

if (isset($_FILES['file'])) {
$file = $_FILES['file']['tmp_name'];
$handle = fopen($file,'r');
$row = 1;
$handle = fopen("$file", "r");
while (($data = fgetcsv($handle, 4096, ",")) !== FALSE) {
$num = count($data);
//echo "<p> $num fields in line $row: <br /></p>\n";
$row++;
for ($c=0; $c < $num; $c++) {

//je met les donnees en miniscule et detecte si l'email est dans la colonne 0 ou 1
//meme chose pour l'url


//je les transformes en miniscule
$data[1]=strtolower($data[1]);
$data[0]=strtolower($data[0]);
//je controle l'entete du csv
if ($data[1]=='emails' && $data[0] == 'links' ) $mode=1 ;
if ($data[1]=='email' && $data[0] == 'link' ) $mode=1 ;
if ($data[1]=='email' && $data[0] == 'links' ) $mode=1 ;
if ($data[1]=='emails' && $data[0] == 'link' ) $mode=1 ;


////meme chose pour le mode 2 il faut changer $data[0] par $data[1]
///c'est à dire si l'on souhaite avoir email,link, il faut recopier le
///meme code et changer tous les $data[0] par $data[1] et $data[1] par $data[0]


}




if ($mode==1)
{
//je controle l'email

$avant_arobase = '[-a-z0-9!#$%&\'*+\\/=?^_`{|}~]';
$nomdudomaine = '([a-z0-9]([-a-z0-9]*[a-z0-9]+)?)';

$caract_allow_before_arobase = '/^' . $atom . '+' .
'(\.' . $avant_arobase . '+)*' .

'@' .
'(' . $nomdudomaine . '{1,63}\.)+' .

$domain . '{2,63}$/i';

// test de l'adresse e-mail
if (preg_match($caract_allow_before_arobase, $data[1])) {


}
else
{

$data[1] = NULL ;


}

$data[1]=strtolower($data[1]);
$data[0]=strtolower($data[0]);

//je controle tous les donnees s'il s'agit bien d'un url et d'un email
///dans le cas contraire, ils seront filtrées


$point = strpos($data[0],".");
if($point=='')
{
$data[0]=NULL;
}


$point = strpos($data[0],"@");
if($point=='')
{
$data[0]=$data[0];
}
else
{
$data[0]=NULL;
}










if ( $data[1] != NULL && $data[0] != NULL )
{
$numberdownload=$numberdownload+1;

$marequete = "INSERT INTO matable SET
monurl ='$data[0]' ,
monemail ='$data[1]'
";




$resultat=mysql_query ($marequete) or die (mysql_error());
}
}




}



//if ( $resultat ){ echo "<p> insertion with Succesfully </p> <p>
//" ;

//si des adresses ont ete enregistrer
if ($numberdownload>0){
echo " <p>You have downloaded $numberdownload combinaisons </p>";
echo "<p>The list Id is : $rowIdListNext </p>";
}

///si aucune adresse a ete enregistrer
if ($existadresse==0 && $numberdownload==0)
{
echo " <p> Error .. Your Csv file has a problem.</p>";
echo " <p> Please notice that your csv file has a header</p>";
}
//si les adresses existe deja
if ($existadresse>0 )
{
echo " <p>$existadresse combinaisons already exist! </p>";

}


//renvoie à la page qui a valider le formulaire...c'est à dire vers formulaire.php
$departure=$_SERVER['HTTP_REFERER'];//recover the adress which the user come from
echo "<meta HTTP-EQUIV=\"Refresh\" content=\"5;URL=$departure \"> " ;

Configuration: Windows XP
Firefox 2.0.0.6

                
14
Mousco
 
Merci énormément pour ton script.
cela m'a vraiment aider.
0
StreM Messages postés 515 Date d'inscription   Statut Membre Dernière intervention   124
 
Un fichier CSV n'est rien d'autre qu'un fichier texte. tous les champs de la base sont séparés par un séparateur (habituellement ; ).
Dans phpmyadmin, tu va dans ta table, tu fais inserer, tout en bas de la page :
"Insérer des données provenant d'un fichier texte dans la tableInsérer des données provenant d'un fichier texte dans la table"
Tu devrais te debrouiller apres.
3
lol
 
J'ai essayé ce que tu m'as dit en créant d'abord ma table, voici ce que phpmyadmin répond :

LOAD DATA LOCAL INFILE 'D:\\Program Files\\EasyPHP1-7\\tmp\\phpD5.tmp' REPLACE INTO TABLE `prod`
FIELDS TERMINATED BY ','
ENCLOSED BY '"'
ESCAPED BY '\\'
LINES TERMINATED BY '\r\n'

MySQL a répondu:
#1148 - Cette commande n'existe pas dans cette version de MySQL
0
said
 
Pour importer des données d'une table exemple.xls vers Mysql, procédez comme suit :
Tout d'abord créer votre base de donnée mysql
1- Ouvrir le fichier exemple.xls et enregistrez le sous exemple.csv
2- Enregistrer le fichier exemple.csv sous exemple.txt
3- Enlever les nom des champs du fichier exemple.txt et enregistrer le, sur votre bureau par exemple
4- Aller sur PhpmyAdmin et ouvrir votre base de donnée
5- Créer une table dans laquelle vous souhaitez Insérer les données provenant de votre fichier texte (exemple.txt). Le nombre du champs de cette table doit etre le même que celui du champs de table exemple.txt ou xls.
6- Dans phpmyadmin, tu va dans ta table, tu clique sur le lien « Insérer des données provenant d'un fichier texte dans la table », un lien tout en bas de la page :
Tu devrais te debrouiller apres. Le fichier a inserer est exemple.txt
1
danbiz Messages postés 3 Date d'inscription   Statut Membre Dernière intervention   1
 
Dans phpmyadmin
selection de ta BD
onglet -> import
choisir le fichier
et go

c'est tout
1

Vous n’avez pas trouvé la réponse que vous recherchez ?

Posez votre question
andré
 
bonjour, je n'arrive pas a importer mon fichier csv dans phpmyadmin et je ne comprend pas comment faire (même avec ce que vous avez écris)

Pouvez vous m'aider?
0
said
 
vous parlez d'une version recente peut etre.
moi j'utiluse phpMyAdmin 2.6.1
0
kalamit
 
Saïd, je cherche le lien dont tu parles et je ne le trouve pas. J'utilise la version 3.2.4. J'affiche ma table mais à part importer un fichier complet, je ne vois pas de lien qui permette d'insérer uniquement les données d'un seul champ à partir d'un fichier text.
Désolé de polluer le threat ...
0