IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Langage PHP Discussion :

Lecture fichier texte volumineux


Sujet :

Langage PHP

  1. #1
    Membre du Club
    Homme Profil pro
    Webmaster
    Inscrit en
    Juin 2011
    Messages
    70
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Juin 2011
    Messages : 70
    Points : 67
    Points
    67
    Par défaut Lecture fichier texte volumineux
    Bonsoir

    J'essaye de rendre un fichier de log visible sur une page web.
    J'utilise donc fgets() et lit chaque ligne.
    Tout va bien jusqu'à la ligne 3439. Au delà, les retour à la ligne saut aléatoires, tout se mélange, rien n'est à sa place..
    J'ai essayé diverses techniques, mettre dans un array chaque ligne, enlever le css, les regex .. mais rien à faire.
    Si vous avez des idées qui pourraientt m'éclairer, voici le code :

    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
     
    $fd = fopen('/home/hlds/server.log', 'r');
    if ($fd) {
       if(feof($fd)) { echo "LE FICHIER EST VIDE!"; }
       else {
    	$i = 0;
    	while (!feof($fd)) {
    	       $buffer = fgets($fd);
    		$i++;
    		// Traitement de la date en dbut de chaque ligne
    		$buffer = preg_replace("#((\d{4})-(\d{2})-(\d{2})\s{1}(\d{2}):(\d{2}):(\d{2}))#","<span class='date'><strong>$4/$3/$2</strong> à <strong>$5</strong>h<strong>$6</strong>mn<strong>$7</strong>s</span>",$buffer);
    						// Traitement des connections
    						$buffer = preg_replace("#\[INFO\]\s+Player\s{1}logged\s{1}in\s{1}in\s{1}world\s{1}(.+)#","<span class='connect'><strong class='actType'>Connection</strong> Demande de connection reçue sur le monde $1</span>",$buffer);
    						$buffer = preg_replace("#\[INFO\]\s{1}(.+)\s{1}\[/(.+)\]\s{1}logged\s{1}in\s{1}with\s{1}entity\s{1}id\s{1}(\d+)\s{1}at\s{1}\(\[(.+)\]\s{1}(.+),\s{1}(.+),\s{1}(.+)\)#","<span class='connect'><strong class='actType'>Connection</strong> prise en charge de <strong>$1</strong> (ip:port <strong>$2</strong>), sous l'entité <strong>$3</strong>, Monde <strong>$4</strong> (positions: $5 - $6 - $7)</span>",$buffer);
    						// Traitement des kicks
    						$buffer = preg_replace("#\[INFO\]\s{1}Disconnecting\s{1}(.+)\s{1}\[/(.+)\]:\s{1}(.+)#","<span class='kick'><strong class='actType'>Expulsion</strong> Le joueur <strong>$1</strong> (ip:port <strong>$2</strong>) vient d'être expulsé pour la raison : <strong>$3</strong></span>",$buffer);
    						// Traitement des déconnections
    						$buffer = preg_replace("#\[INFO\]\s{1}(.+)\s{1}lost\s{1}connection:\s{1}disconnect\.endOfStream#","<span class='connect'><strong class='actType'>Déconnection</strong> Le joueur <strong>$1</strong> a perdu la connection</span>",$buffer);
    						$buffer = preg_replace("#\[INFO\]\s{1}(.+)\s{1}lost\s{1}connection:\s{1}disconnect\.quitting#","<span class='connect'><strong class='actType'>Déconnection</strong> Le joueur <strong>$1</strong> s'est déconnecté</span>",$buffer);
    						// Traitement des warnings
    						$buffer = preg_replace("#\[WARNING\](.+)#","<span class='warning'>$1</span>",$buffer);
    						$buffer = preg_replace("#\[SEVERE\](.+)#","<span class='warning'>$1</span>",$buffer);
    						// Traitement plugin xauth
    						$buffer = preg_replace("#\[xAuth\]\s{1}(.+)\s{1}has\s{1}registered#","<span class='xauthAct'><strong class='actType'>Protection pseudo</strong> Le joueur <strong>$1</strong> vient d'enregistrer son pseudo</span>",$buffer);
    						$buffer = preg_replace("#\[xAuth\]\s{1}(.+)\s{1}has\s{1}logged\s{1}in#","<span class='xauthAct'><strong class='actType'>Protection pseudo</strong> Le joueur <strong>$1</strong> vient de s'identifier</span>",$buffer);
    						// Perte de connection
    						$buffer = preg_replace("#\[INFO\]\s{1}Connection\s{1}reset#","<span class='warning'>Une connection a été perdue</span>",$buffer);
    						// Traitement de player_command autre
    						$buffer = preg_replace("#\[PLAYER_COMMAND\]\s{1}(.+):\s{1}(.+)#","<span class='command'><strong class='actType'>Commande</strong> <strong>$1</strong> écrit la commande : <strong>$2</strong></span>",$buffer);
     
    						// Traitement des infos diverses
    						$buffer = preg_replace("#\[INFO\]\s{1}\[(.+)\](.+)#","<span class='pluginInfo'><strong class='actType'>$1</strong> $2</span>",$buffer);
     
    						echo "(".$i.") ".$buffer."<br />";
     
     
    					}
     
     
    				}		
    			} else { echo "LE FICHIER EST INTROUVABLE!"; }
    			fclose($fd); //fermeture

    Je précise que le fichier atteint généralement entre 30 000 et 40 000 lignes

  2. #2
    Expert éminent sénior

    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    7 920
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 7 920
    Points : 10 726
    Points
    10 726
    Par défaut
    quel est le message d'erreur ?

Discussions similaires

  1. [VB]Probleme lecture fichier text et affichage
    Par clochardevobsy dans le forum VB 6 et antérieur
    Réponses: 3
    Dernier message: 10/03/2006, 08h46
  2. lecture fichier texte et ...
    Par Nils30 dans le forum Langage
    Réponses: 5
    Dernier message: 12/01/2006, 11h55
  3. lecture fichier text et renvoi du contenu en byte *
    Par JulienT dans le forum Réseau
    Réponses: 3
    Dernier message: 02/01/2006, 13h21
  4. Lecture fichier text
    Par krfa1 dans le forum ASP
    Réponses: 13
    Dernier message: 25/11/2005, 08h00
  5. Recherche dans un fichier texte volumineux.
    Par Actarus69 dans le forum VB 6 et antérieur
    Réponses: 17
    Dernier message: 27/07/2005, 17h39

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo