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

Coldfusion Discussion :

Supprimer un onglet dans Excel avec Coldfusion


Sujet :

Coldfusion

  1. #1
    Membre régulier
    Homme Profil pro
    Responsable de projet fonctionnel
    Inscrit en
    Avril 2004
    Messages
    105
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Responsable de projet fonctionnel
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2004
    Messages : 105
    Points : 80
    Points
    80
    Par défaut Supprimer un onglet dans Excel avec Coldfusion
    Bonjour à tous,

    Dans une appli type web, je dois générer un fichier Excel provenant d'un modèle (avec multiples onglets) mais ne contenant qu'un onglet (en fonction des droits des utilisateurs).

    J'ai donc fait ceci... mais impossible de trouver comment supprimer les onglets non nécessaires :
    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
    <cfset onglet = "test">
    <cfset w_date_jour = dateformat(now(),"yyyymmdd")>
    			
    <CFTRY>
       <CFOBJECT        
    	ACTION="CONNECT"
    	CLASS="Excel.Application"
    	NAME="objExcel"
    	TYPE="COM">
    <CFCATCH>
       <CFOBJECT
    	ACTION="CREATE"
    	CLASS="Excel.Application"
    	NAME="objExcel"
    	TYPE="COM">
    </CFCATCH>			   
    </CFTRY>
    			
    <!---Création du fichier Excel --->
    <cfscript>
    	objExcel.Visible = false;
    	objExcel.DisplayAlerts = false;  
    				
            // Ouverture du fichier source
    	objWorkBook_temp = objExcel.Workbooks.Open("#application.temp#\mon_modele_excel.xls");
    	objWorkSheets_temp = objExcel.WorkSheets;
    	numOfSheets = objWorkSheets_temp.Count;
    	
            for(w=numOfSheets; w gt 1; w=w-1){
    		objWorkSheet_temp = objWorkSheets_temp.Item(val(w));			
    					
    		if(objWorkSheet_temp.Name neq #onglet#){
    			//objWorkSheet_temp.Delete();
    		        objWorkSheets_temp.Item(objWorkSheet_temp.Name).Delete();
    		}
    	}
    				
    	fic = "#application.temp#\mon_fichier_" & #w_date_jour# & ".xls";
    	objWorkBook_temp.SaveAs(fic2,Val(1));
    	objWorkBook_temp.Close();
    	objexcel.quit();
    	ReleaseComObject(objexcel);
    </cfscript>
    Et j'ai cette erreur :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    An exception occurred when accessing a Com object field.  
    The cause of this exception was that: AutomationException: 0x800a01a8 - .
    Merci d'avance à tous

  2. #2
    Membre régulier
    Homme Profil pro
    Responsable de projet fonctionnel
    Inscrit en
    Avril 2004
    Messages
    105
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Responsable de projet fonctionnel
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2004
    Messages : 105
    Points : 80
    Points
    80
    Par défaut
    J'ai résolu le problème en écrivant ma boucle FOR comme suit :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    for(w=numOfSheets; w gt 1; w=w-1){
    	objWorkSheet_temp = objWorkSheets_temp.Item(val(w));								
    	objWorkSheet_temp.Activate;
    						
    	if(objWorkSheet_temp.Name neq #onglet#){
    		objWorkSheet_temp.Delete;
    	}
    }
    Apparemment, il fallait activer la feuille pour pouvoir la supprimer... Rien à voir avec CF finalement

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

Discussions similaires

  1. Inserer image dans excel avec PHP
    Par hamzito dans le forum Langage
    Réponses: 5
    Dernier message: 12/08/2011, 12h53
  2. Rechercher une valeur dans excel avec VBA
    Par kebab666 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 27/06/2007, 10h00
  3. deplacement dans Excel avec user form actif
    Par rodrigue62 dans le forum Excel
    Réponses: 5
    Dernier message: 29/03/2007, 12h40
  4. Comment supprimer un bouton dans excel ?
    Par pauletta22 dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 29/05/2006, 09h52
  5. Alignement vertical dans Excel avec OLE
    Par Patrick Seuret dans le forum C++Builder
    Réponses: 6
    Dernier message: 20/11/2005, 15h10

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