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

Documents Java Discussion :

comment ajouter une ligne dans fichier excel sans effacer tout le fichier poi_java


Sujet :

Documents Java

  1. #1
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2017
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Australie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Janvier 2017
    Messages : 9
    Points : 4
    Points
    4
    Par défaut comment ajouter une ligne dans fichier excel sans effacer tout le fichier poi_java
    slt

    comment ajouter une ligne dans un fichier excel sans effacer tout le fichier poi_java
    c'est 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
    17
    18
    19
    20
    21
     
     
     
    //   HSSFWorkbook wb = new HSSFWorkbook();
    //    HSSFSheet sheet = wb.getSheet("ma feuille");
    //   
    //    sheet.shiftRows(currentRow, sheet.getLastRowNum()+1, amount, true,true);
    ////sheet.shiftRows(1,sheet.getLastRowNum(), 1);
    //    HSSFRow row = sheet.createRow(1);
    //    HSSFCell cell = row.createCell((short)0);
    //    cell.setCellValue("rrr1");
    //
    //    row.createCell((short)1).setCellValue("bbbnn1");
    //
    //    FileOutputStream fileOut;
    //    try {
    //      fileOut = new FileOutputStream("bl.xls");
    //      wb.write(fileOut);
    //      fileOut.close();  
    //    } catch (FileNotFoundException e) {
    //      e.printStackTrace();}
    svp aider mon a compléter mon code merci

  2. #2
    Modérateur
    Avatar de wax78
    Homme Profil pro
    Chef programmeur
    Inscrit en
    Août 2006
    Messages
    4 074
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : Belgique

    Informations professionnelles :
    Activité : Chef programmeur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2006
    Messages : 4 074
    Points : 7 978
    Points
    7 978
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Row insertionLigne(Sheet sheet, int ligneindex) {
    	    if(sheet.getLastRowNum() < ligneindex) 
    	        return sheet.createRow(ligneindex);
    	    sheet.shiftRows(ligneindex, sheet.getLastRowNum()+1, 1);
    	    return sheet.createRow(ligneindex);
    	}
    (Les "ça ne marche pas", même écrits sans faute(s), vous porteront discrédit ad vitam æternam et malheur pendant 7 ans)

    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  3. #3
    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 : 54
    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
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    Il faut charger le fichier pour ne pas supprimer les données :

    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
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    public static void main(String[] args) {
    		try {
    			addRow(FILE_NAME, SHEET_NAME, 42, "blahblah", new Date(), 33.33, true);
    		} catch (IOException e) { 
    			e.printStackTrace();
    		}
    		try {
    			addRows(FILE_NAME, SHEET_NAME, new Object[][] {
    				{1, "truc"},
    				{2, "bidule"},
    				{3, "machin"}
    			});
    		} catch (IOException e) { 
    			e.printStackTrace();
    		}
    	}
     
    	public static void addRow(String fileName, String sheetName, Object...values) throws IOException {
     
    		try(Workbook workbook=WorkbookFactory.create(new FileInputStream(fileName))) { 
    		    Sheet sheet = workbook.getSheet(sheetName);
    			addRow(sheet, values);
    			try(FileOutputStream outputStream = new FileOutputStream(fileName)) {
    				workbook.write(outputStream);
    			}
    		} catch (EncryptedDocumentException | InvalidFormatException e) {
    			throw new IOException(e);
    		}
     
    	}
     
    	public static void addRows(String fileName, String sheetName, Object[][] values) throws IOException {
     
    		try(Workbook workbook=WorkbookFactory.create(new FileInputStream(fileName))) { 
    		    Sheet sheet = workbook.getSheet(sheetName);
    		    for(Object[] row : values) {
    		    	addRow(sheet, row);
    		    }
    			try(FileOutputStream outputStream = new FileOutputStream(fileName)) {
    				workbook.write(outputStream);
    			}
    		} catch (EncryptedDocumentException | InvalidFormatException e) {
    			throw new IOException(e);
    		}
     
    	}
     
    	/**
             * Ajoute les valeurs dans une nouvelle ligne en bas
             * @param sheet
             * @param values
             * @return
             */
    	public static Row addRow(Sheet sheet, Object...values) {
    		int rowNum = sheet.getLastRowNum(); 
    	    if ( sheet.getRow(rowNum)!=null ) {
    	    	rowNum++;
    	    } 
    	    return addRow(sheet, rowNum, values);
    	}
     
    	/**
             * Ecrit les valeurs dans la ligne de numéro spécifié
             * @param sheet
             * @param values
             * @return
             */
    	public static Row addRow(Sheet sheet, int rowNum, Object...values) {
    		Row row = sheet.createRow(rowNum);
    		for(int i=0; i<values.length; i++) {
    			Cell cell = row.createCell(i);
    			Object value = values[i];
    			if ( value instanceof String ) {
    				cell.setCellValue((String)value);
    			}
    			else if ( value instanceof Boolean ) {
    				cell.setCellValue((Boolean)value);
    			}
    			else if ( value instanceof Number ) {
    				cell.setCellValue(((Number)value).doubleValue());
    			}
    			else if ( value instanceof Date ) {
    				cell.setCellValue((Date)value);
    			}  
    		}
    		return row;
    	}
    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.

  4. #4
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2017
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Australie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Janvier 2017
    Messages : 9
    Points : 4
    Points
    4
    Par défaut
    moi je veut ajouter a chaque exécution une ligne a la fin du fichier excel sans effacer les anciens

    exemple avant
    Nom : Capture1225.PNG
Affichages : 309
Taille : 4,1 Ko


    exemple après

    Nom : Capture875.PNG
Affichages : 304
Taille : 2,5 Ko

    si pouvait me donner un code qui me permet de faire çà
    merci pour votre aide

  5. #5
    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 : 54
    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
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    C'est exactement ce que fait le code que je t'ai montré ! Tu as essayé au moins ?
    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.

  6. #6
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2017
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Australie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Janvier 2017
    Messages : 9
    Points : 4
    Points
    4
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
     addRow(FILE_NAME, SHEET_NAME, 42, "blahblah", new Date(), 33.33, true);
                    addRows(FILE_NAME, SHEET_NAME, new Object[][] {
                        {1, "truc"},

    comment régler les paramètre de la fonction addRow

  7. #7
    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 : 54
    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
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    Citation Envoyé par iheb11 Voir le message
    comment régler les paramètre de la fonction addRow
    Cela me semble assez explicite :


    1. premier paramètre : le nom du fichier
    2. deuxième paramètre : le nom de la feuille de calcul
    3. ensuite les valeurs


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    addRow(FILE_NAME, SHEET_NAME, 42, "un texte");
    Avant :
    1 texte
    2 autre texte

    Après:
    1 texte
    2 autre texte
    42 un texte
    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.

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

Discussions similaires

  1. Comment ajouter une ligne dans une gridview
    Par zmamovzki dans le forum ASP.NET
    Réponses: 6
    Dernier message: 01/08/2013, 14h36
  2. ajouter une ligne dans un fichier excel en vb.net 2010
    Par AlexLyon dans le forum VB.NET
    Réponses: 2
    Dernier message: 08/08/2011, 20h35
  3. Réponses: 2
    Dernier message: 12/10/2009, 18h28
  4. Comment ajouter une ligne dans un Jtable
    Par fefe69 dans le forum Composants
    Réponses: 1
    Dernier message: 10/03/2009, 11h57
  5. Comment ajouter une ligne dans une feuille ?
    Par vacknov dans le forum Macros et VBA Excel
    Réponses: 14
    Dernier message: 15/11/2007, 07h30

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