Vous ne trouvez pas de réponse à votre problème ? Alors posez la question dans le forum. Souvenez-vous qu'il n'y a jamais de question bête, mais rester dans l'ignorance parce que l'on n'ose pas poser une question, ça c'est une erreur !

Sujet : Comment ouvrir/modifier/ecrire dans un fichier EXcel c#.net WINFORM [ Windows / Formulaire / Winforms / Controls ] (vinzemuls)

mercredi 6 août 2008 à 08:25:29 | Comment ouvrir/modifier/ecrire dans un fichier EXcel c#.net WINFORM

vinzemuls

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.

 


mercredi 6 août 2008 à 08:43:51 | Re : Comment ouvrir/modifier/ecrire dans un fichier EXcel c#.net WINFORM

some_one

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

vendredi 8 août 2008 à 14:45:17 | Re : Comment ouvrir/modifier/ecrire dans un fichier EXcel c#.net WINFORM

vinzemuls

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


vendredi 8 août 2008 à 19:23:04 | Re : Comment ouvrir/modifier/ecrire dans un fichier EXcel c#.net WINFORM

some_one

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

lundi 11 août 2008 à 00:34:41 | Re : Comment ouvrir/modifier/ecrire dans un fichier EXcel c#.net WINFORM

vinzemuls

envoi moi le projet si possible, je te remercie d'avance pour ton temps

lundi 11 août 2008 à 23:21:17 | Re : Comment ouvrir/modifier/ecrire dans un fichier EXcel c#.net WINFORM

some_one

Réponse acceptée !
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.

jeudi 4 décembre 2008 à 22:30:26 | Re : Comment ouvrir/modifier/ecrire dans un fichier EXcel c#.net WINFORM

Leucistic

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




Cette discussion est classé dans : fichier, ouvrir, net, excel, winform


Répondre à ce message

Sujets en rapport avec ce message

Ouvrir fichier excel [ par desopedr ] Bonjour,Voilà mon problème : j'ai developpé une application winforms en C#, base de donnée access, j'ai créé une classe qui importe les données depuis Ouvrir un fichier Excel existant [ par pikapote ] Bonjour,Je voudrais, si possible que quelqu'un me donne le code exact pour ouvrir un fichier Excel existant. En effet, en cherchant ici même et sur le ouvrir un fichier sous excel [ par ansizak ] Bonjour, une question toute bête, comme puis-je ouvrir un fichier directement sous excel ? (jai une appli dans laquelle le contenu d'une datagridview Outils pour ouvrir les fichiers au format MHTL (autre que Excel) [ par toredede ] Bonjour,Je travaille sur Oracle Applications avec BI Publisher pour générer des sorties de traitements.Lorsque je fais une sortie en EXCEL le fichier Embedded Resource [ par sevenace ] Bonjour,Je suis actuellement face un dilemme de taille. Je dois développer un web service capable de recevoir une requête, calculer des données, et le Probleme création de fichier EXCEL [ par aifzaide ] Bonjour,Dans mon site web, je genere un fichier .xls dans lequel je stock des stats. Lorsque je crée le fichier Excel ca passe directement dans le cat .NET C# Application console [ par Seth75 ] Bonjour, Je voudrais savoir comment faire pour sauvegarder le contenu d'un fichier csv dans un fichier txt dans une application console car en web c'e Une DataTable dans un fichier Excel existant [ par toopix ] Salut, Je voudrais copier une table Oracle dans un fichier Excel. Cette table contient plus de 30 000 lignes... et j'ai des soucis de performances Afficher le contenu d'une Hashtable dans un fichier Excel [ par decoalaa ] Bonjour, voila mon problème, j'ai stocké des données dans une hashtable et je veux afficher le contenu dans un fichier Excel, J'ai crée mon fichier et Generer un fichier Excel ou Configurer une librairie COM dans visual studio [ par hasen ] Messieurs, Mesdames bonjour!Je voudrais generer un fichier Excel depuis mon code C# et j'avais trouvé une solution grace à la librairie (dans COM) Mic


Nos sponsors

Sondage...

CalendriCode

Juillet 2009
LMMJVSD
  12345
6789101112
13141516171819
20212223242526
2728293031  

Consulter la suite du CalendriCode

Téléchargements

Logiciels à télécharger sur le même thème :

Comparez les prix Nouvelle version

Photothèque Nouveau !



Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés
Temps d'éxécution de la page : 0,546 sec

Google Coop CodeS-SourceS Google Coop CodeS-SourceS


Certaines images présentes sur le site (notament certains avatars) sont issues des collections IconShock, donc si vous souhaitez utiliser ces icons vous devez les acheter, ne les copiez pas et ne utilisez pas dans vos sites et applications sans les avoir commandé.