Fehler: Sie können eine Excel Listenzeile aus CommandButton Click-Ereignis nicht löschen

SPRACHE AUSWÄHLEN SPRACHE AUSWÄHLEN
Artikel-ID: 823988 - Produkte anzeigen, auf die sich dieser Artikel bezieht
Alles erweitern | Alles schließen

Auf dieser Seite

Problembeschreibung

Eine Erweiterung von verwaltetem Code haben für Excel 2003 erstellt werden. Ihre Projektmappe werden das Click -Ereignis eines MSForms CommandButton -Steuerelements verwendet, um Zeilen aus einer List -Objekt zu entfernen, die sich auf einem Arbeitsblatt befindet. Wenn Sie auf die Schaltfläche, um Liste Zeile entfernen klicken, die Zeile wird nicht entfernt, und möglicherweise eine Fehlermeldung zur Laufzeit.

Status

Microsoft hat bestätigt, dass dies einen Fehler in Excel 2003 ist.

Lösung

Um dieses Problem zu beheben, stellen Sie sicher, dass Befehlsschaltfläche nicht den Fokus hat beim Löschen der Listenzeile. Verwenden Sie eine der folgenden Methoden:
  • Legen Sie die TakeFocusOnClick -Eigenschaft der Befehlsschaltfläche auf false .

    -oder-
  • Markieren Sie die aktuelle Auswahl Arbeitsblatt um den Fokus weg vom Befehlsschaltfläche nutzen.

Abhilfe

Verwenden Sie eine der folgenden Methoden um dieses Problem zu umgehen:
  • Legen Sie die TakeFocusOnClick -Eigenschaft für das Befehlsschaltfläche -Steuerelement auf 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;
    }
    


    -oder-
  • Rufen Sie die Select -Methode für das aktuelle Arbeitsblatt Auswahl , um die Befehlsschaltfläche den Fokus aufheben:
    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();
    }
    

Weitere Informationen

Schritte zum Reproduzieren des Verhaltens

  1. Starten Sie Microsoft Visual Studio .NET 2003.
  2. Zeigen im Menü Datei auf neu , und klicken Sie dann auf Projekt .
  3. In der Liste der Projekttypen erweitern Sie Projekte für Microsoft Office System , und klicken Sie dann auf Visual C#-Projekte . Wählen Sie Excel-Arbeitsmappe in der Vorlage-Liste, und klicken Sie dann auf OK .
  4. Klicken Sie im Microsoft Office Projekt-Assistent - Fertig stellen .
  5. Drücken Sie F5, um das Projekt auszuführen und die Arbeitsmappe in Excel öffnen.
  6. Ändern Sie die Arbeitsmappe wie folgt:
    1. Markieren Sie Zelle A1.
    2. Zeigen im Menü Daten auf Liste , und klicken Sie dann auf Liste erstellen . Das Dialogfeld Liste erstellen wird angezeigt. Klicken Sie auf OK .
    3. Jeder Text Zellen A2, A3 und A4 hinzufügen (a2: A4).
    4. Im Menü Ansicht auf Symbolleisten , und klicken Sie dann auf Steuerelement-Toolbox .
    5. Zeichnen Sie ein Befehlsschaltfläche -Steuerelement auf dem Arbeitsblatt. Der Standardname ist "CommandButton1" .
    6. Speichern Sie die Arbeitsmappe, und beenden Sie Excel.
  7. Fügen Sie für das thisworkbook.cs-Code-Modul den folgenden Code:
    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. Drücken Sie F5, um erstellen und das Projekt auszuführen.
  9. Klicken Sie auf "CommandButton1" .

    Ergebnis Eine Ausnahme wird abgefangen, wenn die Zeile in der Liste löschen. Folgende Fehlermeldung wird angezeigt
    Ausnahme von HRESULT: 0x800A03EC

Eigenschaften

Artikel-ID: 823988 - Geändert am: Montag, 15. Januar 2007 - Version: 2.3
Die Informationen in diesem Artikel beziehen sich auf:
  • Microsoft Office Excel 2003
  • Microsoft Visual Studio Tools for the Microsoft Office System version 2003
Keywords: 
kbmt kbbug kbautomation kbnofix KB823988 KbMtde
Maschinell übersetzter Artikel
Wichtig: Dieser Artikel wurde maschinell und nicht von einem Menschen übersetzt. Die Microsoft Knowledge Base ist sehr umfangreich und ihre Inhalte werden ständig ergänzt beziehungsweise überarbeitet. Um Ihnen dennoch alle Inhalte auf Deutsch anbieten zu können, werden viele Artikel nicht von Menschen, sondern von Übersetzungsprogrammen übersetzt, die kontinuierlich optimiert werden. Doch noch sind maschinell übersetzte Texte in der Regel nicht perfekt, insbesondere hinsichtlich Grammatik und des Einsatzes von Fremdwörtern sowie Fachbegriffen. Microsoft übernimmt keine Gewähr für die sprachliche Qualität oder die technische Richtigkeit der Übersetzungen und ist nicht für Probleme haftbar, die direkt oder indirekt durch Übersetzungsfehler oder die Verwendung der übersetzten Inhalte durch Kunden entstehen könnten.
Den englischen Originalartikel können Sie über folgenden Link abrufen: 823988
Microsoft stellt Ihnen die in der Knowledge Base angebotenen Artikel und Informationen als Service-Leistung zur Verfügung. Microsoft übernimmt keinerlei Gewährleistung dafür, dass die angebotenen Artikel und Informationen auch in Ihrer Einsatzumgebung die erwünschten Ergebnisse erzielen. Die Entscheidung darüber, ob und in welcher Form Sie die angebotenen Artikel und Informationen nutzen, liegt daher allein bei Ihnen. Mit Ausnahme der gesetzlichen Haftung für Vorsatz ist jede Haftung von Microsoft im Zusammenhang mit Ihrer Nutzung dieser Artikel oder Informationen ausgeschlossen.

Ihr Feedback an uns

 

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