BUG: Non ╚ possibile eliminare una riga di elenco di Excel dall'evento CommandButton Click

Traduzione articoli Traduzione articoli
Identificativo articolo: 823988 - Visualizza i prodotti a cui si riferisce l?articolo.
Espandi tutto | Chiudi tutto

In questa pagina

Sintomi

Aver creato un'estensione del codice gestito per Office Excel 2003. La soluzione Ŕ utilizzato l'evento Click di un controllo MSForms CommandButton per rimuovere di righe da un oggetto elenco che si trova su un foglio di lavoro. Quando si fa clic sul pulsante per rimuovere la riga dell'elenco , la riga non viene rimosso e si potrebbe essere visualizzato un errore di run-time.

Status

Microsoft ha confermato che questo un bug in Office Excel 2003.

Risoluzione

Per risolvere il problema, assicurarsi che CommandButton non ha lo stato attivo quando si elimina la riga dell'elenco. Utilizzare uno dei seguenti metodi:
  • Impostare la proprietÓ TakeFocusOnClick CommandButton su false .

    - oppure -
  • Selezionare la selezione del foglio di lavoro corrente per rendere lo stato attivo dal controllo CommandButton .

Workaround

Per ovviare al problema, utilizzare uno dei metodi descritti di seguito:
  • Impostare la proprietÓ TakeFocusOnClick per il controllo CommandButton su false :
    protected void ThisWorkbook_Open()
    {
    	//Get a reference to the first worksheet.
    	ws = (Excel.Worksheet)(ThisWorkbook.Worksheets[1]);
    
    	//Set up the Click event handler for CommandButton1.
    	cb = (MSForms.CommandButton)(this.FindControl("CommandButton1"));
    	cb.Click+= new MSForms.CommandButtonEvents_ClickEventHandler(cbClick);
    
    	cb.TakeFocusOnClick = false;
    }
    


    - oppure -
  • Chiamare il metodo SELECT per il foglio di lavoro corrente Selezione per rimuovere lo stato attivo al controllo CommandButton :
    private void cbClick()
    { 
    	ThisApplication.Selection.GetType().InvokeMember("Select",
    		System.Reflection.BindingFlags.Public | 
    		System.Reflection.BindingFlags.InvokeMethod | 
    		System.Reflection.BindingFlags.Instance,
    		null,
    		ThisApplication.Selection,
    		null);
    	
    	ws.ListObjects[1].ListRows[1].Delete();
    }
    

Informazioni

Procedura per riprodurre il problema.

  1. Avviare Microsoft Visual Studio .NET 2003.
  2. Scegliere Nuovo dal menu file , quindi progetto .
  3. Nell'elenco dei tipi di progetto, espandere Sistema progetti di Microsoft Office e quindi fare clic su Progetti di Visual C# . Selezionare la Cartella di lavoro di Excel nella casella modello e quindi fare clic su OK .
  4. Fare clic su Fine nella Creazione guidata progetto di Microsoft Office .
  5. Premere il tasto F5 per eseguire il progetto e per aprire la cartella di lavoro in Excel.
  6. Modificare la cartella di lavoro nel modo seguente:
    1. Selezionare la cella A1.
    2. Scegliere elenco dal menu dati , quindi Crea elenco . VerrÓ visualizzata la finestra di dialogo Crea elenco . Fare clic su OK .
    3. Aggiungere testo alle celle A2, A3 e A4 (a2: A4).
    4. Scegliere barre degli strumenti dal menu Visualizza , quindi Strumenti di controllo .
    5. Disegnare un controllo CommandButton nel foglio di lavoro. Il nome predefinito Ŕ CommandButton1 .
    6. Salvare la cartella di lavoro e chiudere Excel.
  7. Aggiungere il codice riportato di seguito al modulo codice thisworkbook.cs:
    private MSForms.CommandButton cb;
    private Excel.Worksheet ws;
    
    protected void ThisWorkbook_Open()
    {
    	//Get a reference to the first worksheet.
    	ws = (Excel.Worksheet)(ThisWorkbook.Worksheets[1]);
    
    	//Set up the Click event handler for CommandButton1.
    	cb = (MSForms.CommandButton)(this.FindControl("CommandButton1"));
    	cb.Click+= new MSForms.CommandButtonEvents_ClickEventHandler(cbClick);
    }
    
    private void cbClick()
    {
    	try
    	{
    		//Delete the first row in the list object.
    		ws.ListObjects[1].ListRows[1].Delete();
    	}
    	catch (Exception ex)
    	{
    		System.Diagnostics.Debug.WriteLine(ex.Message);
    		MessageBox.Show(ex.Message);
    	}
    }
    
  8. Premere il tasto F5 per compilare ed eseguire il progetto.
  9. Fare clic su CommandButton1 .

    risultato Un'eccezione viene rilevata durante l'eliminazione della riga nell'elenco. ╚ visualizzato il seguente messaggio di errore
    Eccezione da HRESULT: 0x800A03EC

ProprietÓ

Identificativo articolo: 823988 - Ultima modifica: lunedý 15 gennaio 2007 - Revisione: 2.3
Le informazioni in questo articolo si applicano a:
  • Microsoft Office Excel 2003
  • Microsoft Visual Studio Tools for the Microsoft Office System version 2003
Chiavi:á
kbmt kbbug kbautomation kbnofix KB823988 KbMtit
Traduzione automatica articoli
Il presente articolo Ŕ stato tradotto tramite il software di traduzione automatica di Microsoft e non da una persona. Microsoft offre sia articoli tradotti da persone fisiche sia articoli tradotti automaticamente da un software, in modo da rendere disponibili tutti gli articoli presenti nella nostra Knowledge Base nella lingua madre dell?utente. Tuttavia, un articolo tradotto in modo automatico non Ŕ sempre perfetto. Potrebbe contenere errori di sintassi, di grammatica o di utilizzo dei vocaboli, pi¨ o meno allo stesso modo di come una persona straniera potrebbe commettere degli errori parlando una lingua che non Ŕ la sua. Microsoft non Ŕ responsabile di alcuna imprecisione, errore o danno cagionato da qualsiasi traduzione non corretta dei contenuti o dell?utilizzo degli stessi fatto dai propri clienti. Microsoft, inoltre, aggiorna frequentemente il software di traduzione automatica.
Clicca qui per visualizzare la versione originale in inglese dell?articolo: 823988
LE INFORMAZIONI CONTENUTE NELLA MICROSOFT KNOWLEDGE BASE SONO FORNITE SENZA GARANZIA DI ALCUN TIPO, IMPLICITA OD ESPLICITA, COMPRESA QUELLA RIGUARDO ALLA COMMERCIALIZZAZIONE E/O COMPATIBILITA' IN IMPIEGHI PARTICOLARI. L'UTENTE SI ASSUME L'INTERA RESPONSABILITA' PER L'UTILIZZO DI QUESTE INFORMAZIONI. IN NESSUN CASO MICROSOFT CORPORATION E I SUOI FORNITORI SI RENDONO RESPONSABILI PER DANNI DIRETTI, INDIRETTI O ACCIDENTALI CHE POSSANO PROVOCARE PERDITA DI DENARO O DI DATI, ANCHE SE MICROSOFT O I SUOI FORNITORI FOSSERO STATI AVVISATI. IL DOCUMENTO PUO' ESSERE COPIATO E DISTRIBUITO ALLE SEGUENTI CONDIZIONI: 1) IL TESTO DEVE ESSERE COPIATO INTEGRALMENTE E TUTTE LE PAGINE DEVONO ESSERE INCLUSE. 2) I PROGRAMMI SE PRESENTI, DEVONO ESSERE COPIATI SENZA MODIFICHE, 3) IL DOCUMENTO DEVE ESSERE DISTRIBUITO INTERAMENTE IN OGNI SUA PARTE. 4) IL DOCUMENTO NON PUO' ESSERE DISTRIBUITO A SCOPO DI LUCRO.

Invia suggerimenti

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com