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

vinzemuls 105 Messages postés jeudi 22 mai 2003Date d'inscription 9 septembre 2009 Dernière intervention - 6 août 2008 à 08:25 - Dernière réponse : Antoine Crochet-Damais 16 Messages postés vendredi 11 mars 2011Date d'inscriptionModérateurStatut 8 janvier 2014 Dernière intervention
- 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 

7 réponses

Répondre au sujet
Antoine Crochet-Damais 16 Messages postés vendredi 11 mars 2011Date d'inscriptionModérateurStatut 8 janvier 2014 Dernière intervention - 8 janv. 2014 à 12:26
+2
Utile
Réponse là à la question de savoir comment créer une feuille Excel en C#
Cette réponse vous a-t-elle aidé ?  
Commenter la réponse de Antoine Crochet-Damais
cs_some_one 32 Messages postés mercredi 11 juillet 2007Date d'inscription 22 août 2008 Dernière intervention - 11 août 2008 à 23:21
+1
Utile
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
cs_some_one 32 Messages postés mercredi 11 juillet 2007Date d'inscription 22 août 2008 Dernière intervention - 6 août 2008 à 08:43
0
Utile
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
vinzemuls 105 Messages postés jeudi 22 mai 2003Date d'inscription 9 septembre 2009 Dernière intervention - 8 août 2008 à 14:45
0
Utile
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
cs_some_one 32 Messages postés mercredi 11 juillet 2007Date d'inscription 22 août 2008 Dernière intervention - 8 août 2008 à 19:23
0
Utile
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
vinzemuls 105 Messages postés jeudi 22 mai 2003Date d'inscription 9 septembre 2009 Dernière intervention - 11 août 2008 à 00:34
0
Utile
envoi moi le projet si possible, je te remercie d'avance pour ton temps
Commenter la réponse de vinzemuls
Leucistic 61 Messages postés mercredi 24 septembre 2008Date d'inscription 16 juin 2012 Dernière intervention - 4 déc. 2008 à 22:30
0
Utile
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.