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

Signaler
Messages postés
105
Date d'inscription
jeudi 22 mai 2003
Statut
Membre
Dernière intervention
9 septembre 2009
-
Antoine Crochet-Damais
Messages postés
16
Date d'inscription
vendredi 11 mars 2011
Statut
Webmaster
Dernière intervention
8 janvier 2014
-
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.


 

7 réponses

Messages postés
16
Date d'inscription
vendredi 11 mars 2011
Statut
Webmaster
Dernière intervention
8 janvier 2014
5
Réponse là à la question de savoir comment créer une feuille Excel en C#
Messages postés
32
Date d'inscription
mercredi 11 juillet 2007
Statut
Membre
Dernière intervention
22 août 2008
1
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.
Messages postés
32
Date d'inscription
mercredi 11 juillet 2007
Statut
Membre
Dernière intervention
22 août 2008
1
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
Messages postés
105
Date d'inscription
jeudi 22 mai 2003
Statut
Membre
Dernière intervention
9 septembre 2009

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
Messages postés
32
Date d'inscription
mercredi 11 juillet 2007
Statut
Membre
Dernière intervention
22 août 2008
1
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
Messages postés
105
Date d'inscription
jeudi 22 mai 2003
Statut
Membre
Dernière intervention
9 septembre 2009

envoi moi le projet si possible, je te remercie d'avance pour ton temps
Messages postés
61
Date d'inscription
mercredi 24 septembre 2008
Statut
Membre
Dernière intervention
16 juin 2012
1
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