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

Développement Web en Java Discussion :

Copie de pages web, seul le dernier fichier n'est pas vide


Sujet :

Développement Web en Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre Expert
    Homme Profil pro
    Inscrit en
    Octobre 2011
    Messages
    2 910
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Octobre 2011
    Messages : 2 910
    Par défaut Copie de pages web, seul le dernier fichier n'est pas vide
    Bonjour,

    J’essaie de copier plusieurs pages web automatiquement, le lien est le même mise à part le numéro n qui varie : "`http://..../n.htm"...

    Le problème c'est que seul le dernier fichier contient la page web, les premiers fichiers sont vides...


    Code : 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
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    import java.io.*;
    import java.net.*;
     
    public class Test
    {
       public static void main(String args[])
       {
          BufferedReader urlReader = null;
          FileWriter localFile = null;
          String urlBase =  "http://..../" ;  
          String urlComplet;
          String nomDuFichier ;
          String s;
     
          try{
     
            for(int i=1; i<9;i++ ) {
     
            urlComplet = urlBase + Integer.toString(i) + ".htm";
            nomDuFichier = "Page" + Integer.toString(i) + ".html";
     
            System.out.println("Lien de la page : " + urlComplet);
             System.out.println("Nom du fichier  : " + nomDuFichier + "\n");
     
     
            urlReader = new BufferedReader(new InputStreamReader(new URL(urlComplet).openStream()));
            localFile = new FileWriter(new File(nomDuFichier)); 
     
     
            while((s = urlReader.readLine()) != null){localFile.write(s);}
     
     
            }       
     
          }
          catch(Exception e){
            System.out.println("Erreur : " + e);
          } finally {
     
            if (urlReader!=null) {
                try {
                    urlReader.close();
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
     
            if (localFile!=null) {
                try {
                    localFile.close();
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
     
          }
          System.out.println("Fin");
       }
     
    }
    Quelqu'un pourrait-il m'expliquer où est le problème dans le code ?

    Merci.

  2. #2
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Billets dans le blog
    2
    Par défaut
    Salut,

    Le problème est le close() des flux en dehors de la boucle, ce qu'il fait que seul les flux créés dans la dernière itération sont fermés. Pour le flux en sortie, le résultat est que seul le dernier fichier écrit est rempli.

    Par ailleurs, utiliser le try-with-resource t'évitera ce genre de problème :

    Code : 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
    		for (int i = 1; i < 9; i++) {
     
    			String urlComplet = urlBase + i + ".htm";
    			String nomDuFichier = "Page" + i + ".html";
     
    			System.out.println("Lien de la page : " + urlComplet);
    			System.out.println("Nom du fichier  : " + nomDuFichier + "\n");
     
    			try (BufferedReader urlReader = new BufferedReader(new InputStreamReader(
    					new URL(urlComplet).openStream()))) {
     
    				try( BufferedWriter localFile = new BufferedWriter(new FileWriter(nomDuFichier))) {
     
    					String s;
    					while((s = urlReader.readLine()) != null) {
    						localFile.write(s);
    						localFile.newLine();
    					}
     
    				}
     
    			}
    			catch(IOException e) {
    				e.printStackTrace();
    			}
     
     
    		}
     
    	}
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  3. #3
    Membre Expert
    Homme Profil pro
    Inscrit en
    Octobre 2011
    Messages
    2 910
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Octobre 2011
    Messages : 2 910
    Par défaut
    Salut,

    Oui c'était bien un problème de fermeture, j'ai ajouté "urlReader.close();" & "localFile.close();" dans la boucle et ça a fonctionné.

    J'ai regardé ton code, il a l'air plus concis et meilleur.

    Merci + 1 + résolu.

  4. #4
    Membre Expert
    Homme Profil pro
    Inscrit en
    Octobre 2011
    Messages
    2 910
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Octobre 2011
    Messages : 2 910
    Par défaut
    Salut,

    Je me suis aperçu que les fichiers copiés ne sont pas exactement les mêmes que ceux d'origine même si les pages s'affichent correctement dans le navigateur...

    C'est la ligne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    while((s = urlReader.readLine()) != null){localFile.write(s);
    qui pose problème, en effet avec ce code les sauts de ligne ne sont pas copiés, du coup je me retrouve avec des fichiers qui ne contiennent qu'une ligne...

    Je comprends mieux pourquoi tu as rajouté dans ton code !

    Par contre je ne sais pas ce qu'est le "try-with-resource"... Je vais chercher...

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [XL-2007] Récup par Excel d'éléments de la page web active et pilotage Fichier journal Word
    Par Rando31 dans le forum Macros et VBA Excel
    Réponses: 0
    Dernier message: 14/12/2014, 18h14
  2. copie cellule page web coller excel
    Par hakoko dans le forum C#
    Réponses: 1
    Dernier message: 17/05/2013, 17h16
  3. Réponses: 5
    Dernier message: 20/02/2011, 17h10
  4. fermer une page web générée par un fichier php.
    Par timoun dans le forum Général JavaScript
    Réponses: 6
    Dernier message: 30/05/2009, 20h40
  5. Réponses: 18
    Dernier message: 30/06/2005, 13h30

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