vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#
TOP-Angebot: 17 bzw. 24 Entwickler-Vollversionen zum unschlagbaren Preis!  
 vb@rchiv Quick-Search: Suche startenErweiterte Suche starten   Impressum  | Datenschutz  | vb@rchiv CD Vol.6  | Shop Copyright ©2000-2024
 
zurück

 Sie sind aktuell nicht angemeldet.Funktionen: Einloggen  |  Neu registrieren  |  Suchen

VB.NET - Ein- und Umsteiger
For-Each-Schleife funktioniert nicht 
Autor: Softsphere
Datum: 18.05.06 08:04

Hallo,

ich habe in MS Excel 2003 einen Makro geschrieben, der in Zeile 4 (beginnend ab der Spalte A) alle Zellen nach Inhalten durchsucht.
Also angefangen bei Range("A4").Value, Range("B4").Value, Range("C4").Value usw bis eine leere Zelle gefunden wurde, dann soll beendet werden.

In VBA habe ich das über eine Schleife gelöst:

    For Each C In Sheets("Basicdata").Range("4:4")
 
        If C.Value <> "" Then
 
 
	debug.print C.Value		'<- um den aktuellen Zelleninhalt auszugeben
	debug.print C.Address	'<- um die aktuelle Spaltenbezeichnung (z. B. A) 
' auszugeben
 
        Else
            Exit For
        End If
 
    Next C
In VBA funktioniert das auch problemlos.

Aber in VB.NET stoße ich auf einige Probleme damit. So wird mir z. B. das "C" in der For-Each-Schleife als Fehler markiert.
Ich habe es daher deklariert: Dim C as Object. Bin mir nicht sicher, ob der Datentyp korrekt ist?

Im Internet habe ich schon ein paar Beispiele gefunden bzgl. For-Each-Schleifen in Verbindung mit Listen. Aber nicht wie man in Excel die Zellen einer Zeile sich ausgeben lässt…

In VB.NET habe ich den obigen VBA-Code entsprechend umgeschrieben:

    Public oXL As Excel.Application
    Public oWB As Excel.Workbook                    'Öffnen der Datei
    Public oSheetBasicdata As Excel.Worksheet       'Aufruf der Tabelle 
    ' "Basicdata"
    Public oRng As Excel.Range                      'eine Zelle wird instanziert
    Dim xElement As Object
 
        ' Start Excel and get Application object.
        oXL = CreateObject("Excel.Application")
        oXL.Visible = True
 
        'Aufruf der xls-Datei test.xls
        oWB = oXL.Workbooks.Open("C:\test.xls")
 
        'Aufruf der Tabelle "Basicdata"
        oSheetBasicdata = oWB.Sheets("Basicdata")
 
        'der Zelle oRng wird die Spalte A42 im Basicdata-Sheet zugewiesen
        oRng = oSheetBasicdata.Range("4:4")
 
        'MessageBox.Show(oRng.Row.ToString())
 
        For Each xElement In oRng
            MessageBox.Show(CType(xElement, String))
        Next
Bekomme aber leider folgende Fehlermeldung von meinem VS.NET:

An unhandled exception of type 'System.Runtime.InteropServices.COMException' occurred in mscorlib.dll
Additional information: Member nicht gefunden.


cu
Chris
alle Nachrichten anzeigenGesamtübersicht  |  Zum Thema  |  Suchen

 ThemaViews  AutorDatum
For-Each-Schleife funktioniert nicht734Softsphere18.05.06 08:04

Sie sind nicht angemeldet!
Um auf diesen Beitrag zu antworten oder neue Beiträge schreiben zu können, müssen Sie sich zunächst anmelden.

Einloggen  |  Neu registrieren

Funktionen:  Zum Thema  |  GesamtübersichtSuchen 

nach obenzurück
 
   

Copyright ©2000-2024 vb@rchiv Dieter Otter
Alle Rechte vorbehalten.
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein.

Diese Seiten wurden optimiert für eine Bildschirmauflösung von mind. 1280x1024 Pixel