Rechercher : dans
Par :

[php]Import fichier .txt dans BDD Mysql

Dernière réponse le 26 jun 2008 à 22:54:28 chot, le 27 avr 2006 à 15:43:07 
 Signaler ce message aux modérateurs

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://www.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

Meilleures réponses pour « [php]Import fichier .txt dans BDD Mysql » dans :
MySQL - Chargement d'un fichier texte dans une table VoirPour charger une fichier texte défini comme suit : $ tail /home/user1/test.txt 'nom1',1,9 'nom2',2,3 'nom3',3,54 'nom4',4,2 'nom5',5,9 Dans une table définie comme suit : CREATE TABLE chargertest ( ...
Fichier TXT VoirFormat TXT Un fichier TXT est un fichier texte, c'est-à-dire un simple fichier contenant du texte au format ASCII. Pour ouvrir ou modifier un tel fichier, il suffit d'utiliser le bloc-notes ou un éditeur de texte traditionnel.
PHP - Les fichiers VoirLa gestion des fichiers avec PHP Avec PHP, la création ou la lecture de fichiers est, une fois de plus, assez simple. Il existe une multitude de fonctions dédiées à l'utilisation des fichiers. La communication entre le script PHP et le fichier...

1

kilian, le 28 avr 2006 à 16:54:29
  • +3

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

//On prend le contenu du fichier
$content=file_get_contents('http://www.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....

Répondre à kilian

2

kilian, le 28 avr 2006 à 17:07:43

Bon faudra bidouiler un peu ça parce que les colonnes ne sont pas toujours séparées par des tabulations à ce que je vois.

Répondre à kilian

3

bibah, le 26 jun 2008 à 17:16:31

Quant a moi je vourais savoir comment creer un fichier d'enregistrement a part ,ensuite l charger dans une TABLE qui a ete cree davance
je sais k la commande ki sert de charger est la suivante LOAD DATA
MAIS JE NE SAIS PAS COMMENT CREER CE FICHIER
merci de m'aider

Répondre à bibah

4

 [o.o]REplay, le 26 jun 2008 à 22:54:28

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

Répondre à [o.o]REplay