Comment ouvrir/modifier/ecrire dans un fichier EXcel c#.net WINFORM [Résolu]

Messages postés
105
Date d'inscription
jeudi 22 mai 2003
Dernière intervention
9 septembre 2009
- 6 août 2008 à 08:25 - Dernière réponse :
Messages postés
16
Date d'inscription
vendredi 11 mars 2011
Statut
Modérateur
Dernière intervention
8 janvier 2014
- 8 janv. 2014 à 12:26
Bonjour,

après pas mal de recherches, j'ai réussi à trouver comment lire un fichier EXCEL. or je ne trouve pas le moyen d'écrire à la suite du fichier par exemple ou même en créer un nouveau.

j'ai trouvé du code pour du CSV ou en XML et renommer le fichier en xls mais j'aimerai savoir s'il n'existe pas un autre moyen plus propre.

Je vous remercie de votre aide.


Je travaille sur VS 2005, c#.net et en WINFORM.


 
Afficher la suite 

Votre réponse

7 réponses

Meilleure réponse
Messages postés
16
Date d'inscription
vendredi 11 mars 2011
Statut
Modérateur
Dernière intervention
8 janvier 2014
8 janv. 2014 à 12:26
2
Merci
Réponse là à la question de savoir comment créer une feuille Excel en C#

Merci Antoine Crochet-Damais 2

Avec quelques mots c'est encore mieux Ajouter un commentaire

Codes Sources a aidé 90 internautes ce mois-ci

Commenter la réponse de Antoine Crochet-Damais
Messages postés
32
Date d'inscription
mercredi 11 juillet 2007
Dernière intervention
22 août 2008
11 août 2008 à 23:21
1
Merci
Voila tu peux telecharger le projet par ce lien
http://www.codeproject.com/KB/cs/Excel_and_C_.aspx

j'espere que ça t'aidera

Bonne chance.
Commenter la réponse de cs_some_one
Messages postés
32
Date d'inscription
mercredi 11 juillet 2007
Dernière intervention
22 août 2008
6 août 2008 à 08:43
0
Merci
Voici une classe que tu peut utliser pour ecrire dans un fichier Excel

    class CreateExcelDoc
    {
        private Excel.Application app = null;
        private Excel.Workbook workbook = null;
        private Excel.Worksheet worksheet = null;
        private Excel.Range workSheet_range = null;
        public CreateExcelDoc()
        {
            createDoc();
        }

        public void createDoc()
        {
            try
            {
                app = new Excel.Application();
                app.Visible = true;
                workbook = app.Workbooks.Add(1);
                worksheet = (Excel.Worksheet)workbook.Sheets[1];
            }
            catch (Exception e)
            {
                Console.Write("Error");
            }
            finally
            {
            }
        }

        public void createHeaders(int row, int col, string htext, string cell1,
        string cell2, int mergeColumns, string b, bool font, int size, string
        fcolor)
        {
            worksheet.Cells[row, col] = htext;
            workSheet_range = worksheet.get_Range(cell1, cell2);
            workSheet_range.Merge(mergeColumns);
            switch (b)
            {
                case "YELLOW":
                    workSheet_range.Interior.Color = System.Drawing.Color.Yellow.ToArgb();
                    break;
                case "GRAY":
                    workSheet_range.Interior.Color = System.Drawing.Color.Gray.ToArgb();
                    break;
                case "GAINSBORO":
                    workSheet_range.Interior.Color = System.Drawing.Color.Gainsboro.ToArgb();
                    break;
                case "Turquoise":
                    workSheet_range.Interior.Color = System.Drawing.Color.Turquoise.ToArgb();
                    break;
                case "PeachPuff":
                    workSheet_range.Interior.Color = System.Drawing.Color.PeachPuff.ToArgb();
                    break;
                default:
                    //  workSheet_range.Interior.Color = System.Drawing.Color..ToArgb();
                    break;
            }
            workSheet_range.Borders.Color = System.Drawing.Color.Black.ToArgb();
            workSheet_range.Font.Bold = font;
            workSheet_range.ColumnWidth = size;
            if (fcolor.Equals(""))
            {
                workSheet_range.Font.Color = System.Drawing.Color.White.ToArgb();
            }
            else
            {
                workSheet_range.Font.Color = System.Drawing.Color.Black.ToArgb();
            }
        }
        public void addData(int row, int col, string data, string cell1, string cell2, string format)
        {
            worksheet.Cells[row, col] = data;
            workSheet_range = worksheet.get_Range(cell1, cell2);
            workSheet_range.Borders.Color = System.Drawing.Color.Black.ToArgb();
            workSheet_range.NumberFormat = format;
        }
    }

Pour utiliser cette classe tu peux faire appel par exemple par cette methode

    protected void Button6_Click(object sender, EventArgs e)
    {
        CreateExcelDoc excell_app = new CreateExcelDoc();
        //creates the main header
        excell_app.createHeaders(5, 2, "Total of Products", "B5", "D5", 2, "YELLOW", true, 10, "n");
        //creates subheaders
        excell_app.createHeaders(6, 2, "Sold Product", "B6", "B6", 0, "GRAY", true, 10, "");
        excell_app.createHeaders(6, 3, "", "C6", "C6", 0, "GRAY", true, 10, "");
        excell_app.createHeaders(6, 4, "Initial Total", "D6", "D6", 0, "GRAY", true, 10, "");
        //add Data to to cells
        excell_app.addData(7, 2, "114287", "B7", "B7", "#,##0");
        excell_app.addData(7, 3, "", "C7", "C7", "");
        excell_app.addData(7, 4, "129121", "D7", "D7", "#,##0");
        //add percentage row
        excell_app.addData(8, 2, "", "B8", "B8", "");
        excell_app.addData(8, 3, "=B7/D7", "C8", "C8", "0.0%");
        excell_app.addData(8, 4, "", "D8", "D8", "");
        //add empty divider
        excell_app.createHeaders(9, 2, "", "B9", "D9", 2, "GAINSBORO", true, 10, "");
    }

Je crois qu'il faut ajouter une reference COM Microsoft.Excel quelque chose comme ça

J'espere que ça va t'aider.
Bonne journée
Commenter la réponse de cs_some_one
Messages postés
105
Date d'inscription
jeudi 22 mai 2003
Dernière intervention
9 septembre 2009
8 août 2008 à 14:45
0
Merci
Merci pour ton code mais moi celà ne fonctionne pas j'ai certains propriétés qui existent pas comme borders.Color par exemple ensuite

worksheet.Cells[row, col] = data; je dois mettre des ()  à la place des [] et je suis bien en c#.net

J'ai ajouter Excel etc...

Pourrais-tu me faire un projet qui fonctionne avec ton code ?

que je puisse voir où il y a un problème. Merci
Commenter la réponse de vinzemuls
Messages postés
32
Date d'inscription
mercredi 11 juillet 2007
Dernière intervention
22 août 2008
8 août 2008 à 19:23
0
Merci
Cette classe marche chez moi.

peut etre il te manque using System.IO;

Pour utliliser le classe tu met la classe avant Page_Init()  (Bref la premiere methode definit)

ensuite tu creé un bouton et lorsque tu clique fait l'evenement button_Click() definit un peu plus haut.

Si ça marche pas. je t'envoyerai le projet.

Bonne week-end
Commenter la réponse de cs_some_one
Messages postés
105
Date d'inscription
jeudi 22 mai 2003
Dernière intervention
9 septembre 2009
11 août 2008 à 00:34
0
Merci
envoi moi le projet si possible, je te remercie d'avance pour ton temps
Commenter la réponse de vinzemuls
Messages postés
61
Date d'inscription
mercredi 24 septembre 2008
Dernière intervention
16 juin 2012
4 déc. 2008 à 22:30
0
Merci
Bonjour,

Je cherche depuis un certain, mais en vain, à modifier un fichier excel préalablement créé.
Partout je trouve comment créé un fichier, mais jamais en ouvrir un ?

Savez-vous comment faire ?

Merci d'avance

L'ouverture de l'esprit n'est pas une fracture du crâne
Commenter la réponse de Leucistic

Vous n'êtes pas encore membre ?

inscrivez-vous, c'est gratuit et ça prend moins d'une minute !

Les membres obtiennent plus de réponses que les utilisateurs anonymes.

Le fait d'être membre vous permet d'avoir un suivi détaillé de vos demandes et codes sources.

Le fait d'être membre vous permet d'avoir des options supplémentaires.