[php]Import fichier .txt dans BDD Mysql
chot
Messages postés
21
Statut
Membre
-
[o.o]REplay Messages postés 385 Statut Membre -
[o.o]REplay Messages postés 385 Statut Membre -
Bonjour, je suis en stage au service informatique du contre espionnage français et je cherche une solution pour importer un fichier texte en php. Avec une mise à jour toute les 6 h.
Voici l'adresse:
http://ww11.satcodx1.com/_data/0130.txt
Il contient des informations non confidentielles séparées par des tabulations et je souhaite remplir une BDD MySql avec certaines colonnes comme PID, SR ...
L'idée serait de remplir un tableau en php avec les informations triées par colonne. Mais je ne sais pas comment l'importer et le remettre en ordre. Si quelqu'un voit comment faire! Merci
Voici l'adresse:
http://ww11.satcodx1.com/_data/0130.txt
Il contient des informations non confidentielles séparées par des tabulations et je souhaite remplir une BDD MySql avec certaines colonnes comme PID, SR ...
L'idée serait de remplir un tableau en php avec les informations triées par colonne. Mais je ne sais pas comment l'importer et le remettre en ordre. Si quelqu'un voit comment faire! Merci
A voir également:
- [php]Import fichier .txt dans BDD Mysql
- Fichier bin - Guide
- Fichier epub - Guide
- Fichier rar - Guide
- Comment réduire la taille d'un fichier - Guide
- Fichier .dat - Guide
4 réponses
Le mettre à jour toutes les 6 heures?
Tu auras besoin d'un planificateur de tâche pour lancer ton script toutes les 6 heures (il faudra que tu utilises un script php sans passer par une page web).
Typiquement dans un fichier, les lignes sont séparées par le caractère "\n" et les tabulations sont représentées par "\t".
Donc avec la fonction explode, c'est tout vu:
http://fr3.php.net/manual/fr/function.explode.php
Ce message s'autodétruira dans 5 secondes....
Tu auras besoin d'un planificateur de tâche pour lancer ton script toutes les 6 heures (il faudra que tu utilises un script php sans passer par une page web).
Typiquement dans un fichier, les lignes sont séparées par le caractère "\n" et les tabulations sont représentées par "\t".
Donc avec la fonction explode, c'est tout vu:
http://fr3.php.net/manual/fr/function.explode.php
//On prend le contenu du fichier
$content=file_get_contents('http://ww11.satcodx1.com/_data/0130.txt','r');
//On sépare par ligne
$content=explode("\n", $content);
//On sépare chaque ligne par colonne
for($i=0;$i<sizeof($content);$i++)
{
$content[$i] = explode("\t", $content[$i]);
}
//Affichage pour le test
print_r($content);
?>
Ce message s'autodétruira dans 5 secondes....
Bonjour,
Fais une page PHP chargée de lire ton fichier texte:
pour celà, tu pourra utiliser fopen fread, fclose:
http://www.manuelphp.com/php/function.fread.php
ton fichier texte n'étant plus disponible dans ton lien, je ne vois pas trop les champs que tu veux insérer dans ta base, mais pour scanner les chaines de caractères lues, tu pourra utiliser sscanf, ou bien parcourir tes chaines de caractères avec une boucle for jusqu'a trouver un caractère de séparation (genre ;)
ensuite tu n'as plus qu'a insérer ça dans tes tables.
Pour ce qui est d'executer cette action periodiquement-> CRON (vu que vous étes sous redhat ) programme déjà intégré à ton serveur UNIX, permettant d'executer des scripts régulièrement.
bonne continuation
Fais une page PHP chargée de lire ton fichier texte:
pour celà, tu pourra utiliser fopen fread, fclose:
http://www.manuelphp.com/php/function.fread.php
ton fichier texte n'étant plus disponible dans ton lien, je ne vois pas trop les champs que tu veux insérer dans ta base, mais pour scanner les chaines de caractères lues, tu pourra utiliser sscanf, ou bien parcourir tes chaines de caractères avec une boucle for jusqu'a trouver un caractère de séparation (genre ;)
ensuite tu n'as plus qu'a insérer ça dans tes tables.
Pour ce qui est d'executer cette action periodiquement-> CRON (vu que vous étes sous redhat ) programme déjà intégré à ton serveur UNIX, permettant d'executer des scripts régulièrement.
bonne continuation
Bon faudra bidouiler un peu ça parce que les colonnes ne sont pas toujours séparées par des tabulations à ce que je vois.