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

avec Java Discussion :

openCSV : bug dû au caractère "


Sujet :

avec Java

  1. #1
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Novembre 2008
    Messages
    1
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2008
    Messages : 1
    Points : 1
    Points
    1
    Par défaut openCSV : bug dû au caractère "
    Bonsoir,

    en cette veille de we, je seche sur un pb à la ... :

    Dans mon .csv, le separateur de cellule est le caractere ";" .

    Quand dans une ligne, un guillemet n'est pas fermé, opencsv considere que tous les lignes suivantes font parties de la ligne courante.

    Comment faire pour qu'il ne reagisse pas ainsi ?


    Merci les amis...


    ah oui, voici un bout de mon code :
    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
     
    csvReader = new CSVReader(isr, ";");
    csvReader = new
     
    while ((row = csvReaderReadNext(csvReader)) != null) {
    	nbRow++;
     
    	incident = new Incident(row);
     
    	if (incident.isValid()) {
    		listIncident.add(incident);
    		nbRowInsertedIncident++;
    	} else {
    		nbRowErrorsIncident++;
    	}
    }

  2. #2
    Membre expérimenté
    Avatar de yotta
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Septembre 2006
    Messages
    1 088
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Industrie

    Informations forums :
    Inscription : Septembre 2006
    Messages : 1 088
    Points : 1 540
    Points
    1 540
    Par défaut Pourquoi pas...
    Bonjour,

    Je ne connaissais pas javacsv.jar, donc je ne pourrais pas vous donner de solution miracle. Mais s'il s'agit bien d'un bug, et que vous ne pouvez mettre la main sur sa correction, vous pouvez essayer cela :
    Ouvrez votre fichier csv avec un BufferedReader à travers un FileReader, et lisez-le ligne par ligne. Stockez chaque ligne lue dans une String, puis, exploitez la méthode split de String avec l'expression régulière ";".
    Ainsi, vous obtiendrez instantannément après lecture de la ligne le tableau de chaîne que renvoie la méthode split(expression régulière). La position dans ce tableau de chaine correspondant alors à la colonne.
    Il vous faudra bien sûr créer une classe qui fait tout ça et réponde la même chose que l'objet csvReader que vous utilisez dans votre extrait de code.
    C'est peut-être plus lourd, mais une fois la classe créée, vous aurez en quelque sorte votre propre csvReader sans bug...
    Une technologie n'est récalcitrante que par ce qu'on ne la connait et/ou comprend pas, rarement par ce qu'elle est mal faite.
    Et pour cesser de subir une technologie récalcitrante, n'hésitez surtout pas à visiter les Guides/Faq du site !

    Voici une liste non exhaustive des tutoriels qui me sont le plus familiers :
    Tout sur Java, du débutant au pro : https://java.developpez.com/cours/
    Tout sur les réseaux : https://reseau.developpez.com/cours/
    Tout sur les systèmes d'exploitation : https://systeme.developpez.com/cours/
    Tout sur le matériel : https://hardware.developpez.com/cours/

Discussions similaires

  1. Réponses: 7
    Dernier message: 21/10/2010, 13h30
  2. [.NET 2.0] Xml bug avec le caractère &
    Par fix105 dans le forum ASP.NET
    Réponses: 1
    Dernier message: 29/04/2008, 10h59
  3. Remplacer caractère ' ( quote ) par "\n"
    Par Eric45 dans le forum C++
    Réponses: 3
    Dernier message: 28/11/2007, 00h56

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