Zum Inhalt springen

Visual Studio 2005 Problem? - Listenvergleich


Empfohlene Beiträge

Geschrieben

Hi Community,

ich schreibe aktuell eine Import-Funktion für CSV-Dateien.

Seit ca. 1 Woche kämpfe ich mit dem Problem,

die Daten der DB (list1) mit den Importdaten (list2)

zu synchronisieren.

Ich benutze Visual Studio 2005. (2008 darf nicht verwendet werden)

list1 wird mit list2 erfolgreich verglichen, jedoch der letzte Prüfvorgang,

der abprüft, ob sich das aktuelle item (in meinem Fall Instanz einer Meldungsklasse)

bereits in der "fehlendeEintraege"(liste) befindet.

Problem der ganzen Sache:

Beim letzten Vergleich, wie im letzten Absatz beschrieben,

kommt immer das gleiche Ergebnis raus - das aktuelle Item ist in der

Liste "fehlendeEintraege" nicht vorhanden. (jedoch ist dieses bereits vorhanden!!!)

versuchte Methoden/Techniken:

- Contains(obj)

- Equals(obj)

- IndexOf(i) (auf -1 prüfen)

- per Schleife durchlaufen und direkt prüfen

verblüffend:

--> wenn ich alle Properties der Instanz mit allen Properties der anderen Instanz vergleiche,

so macht er es richtig und gibt mir den richtigen Wert zurück.

Direkter Vergleich beider Instanzen führt zum falschen Ergebnis.

Zur Verdeutlichung:

--> 3 Listen werden verwendet (1. DB-Files, 2. Import-Files, 3. Ergebnisliste in der die zu importierenden Daten aufgenommen werden)

Ich hoffe Ihr könnt mir helfen!

Gruß

SystemCrash

Geschrieben

Was ich gerne bei Listen mache ist nicht mit Foreach durchgehen, sondern mit for(i = list.Lenght - 1, i>=0, i--) (oder so), dann kann ich auch Items aus der betrachtenden Liste entfernen.

Ob das für dein besagtees Problem was nützt, steht jedoch auf einem anderen Blatt^^

gruß

Geschrieben
Was ich gerne bei Listen mache ist nicht mit Foreach durchgehen, sondern mit for(i = list.Lenght - 1, i>=0, i--) (oder so), dann kann ich auch Items aus der betrachtenden Liste entfernen.

StreamReader str = new StreamReader(sFile);


str.ReadLine();


while (str.EndOfStream == false)

{

	String[] stemp = str.ReadLine().Split(';'); //<- kann natürlich auch ein anderes Trennzeichen sein


	for (int i = 0; i < stemp.Length; i++)

	{

		//Hier suchst du einfach den aktuellen Wert in der DB

		//müsste doch mit SQL ein wirklich leichtes sein?

	}

}

str.Close();

Da hast du doch die Lösung schon fast komplett vorgekaut :P

Geschrieben (bearbeitet)

Die Listen sind bereits gefüllt, er benötigt also wohl keine Methoden um die csv zu splitten... Ich kann mich nur wiederholen, Code?

Ich versteh das nicht, wenn du die Equals Methode überschreibst und dort alle Properties vergleichst, wieso kommt dabei was anderes heraus als beim direkten Vergleich... :/

Bearbeitet von 0815FIA
Geschrieben

HI @ll..

war mein Fehler,

hab nicht drangedacht das man zwei versch. Instanzen einer Klasse

nicht wie zwei Wertetypen vergleichen kann...

Somit bekam ich beim Vergleich der Properties (Wertevergleich) mein gewün. Ergebnis und anders beim Referenzvergleich eben das Gegenteil!

Danke für alle Mühen und Antworten! :)

Gruß

SysCrash

Dein Kommentar

Du kannst jetzt schreiben und Dich später registrieren. Wenn Du ein Konto hast, melde Dich jetzt an, um unter Deinem Benutzernamen zu schreiben.

Gast
Auf dieses Thema antworten...

×   Du hast formatierten Text eingefügt.   Formatierung wiederherstellen

  Nur 75 Emojis sind erlaubt.

×   Dein Link wurde automatisch eingebettet.   Einbetten rückgängig machen und als Link darstellen

×   Dein vorheriger Inhalt wurde wiederhergestellt.   Editor leeren

×   Du kannst Bilder nicht direkt einfügen. Lade Bilder hoch oder lade sie von einer URL.

Fachinformatiker.de, 2024 by SE Internet Services

fidelogo_small.png

Schicke uns eine Nachricht!

Fachinformatiker.de ist die größte IT-Community
rund um Ausbildung, Job, Weiterbildung für IT-Fachkräfte.

Fachinformatiker.de App

Download on the App Store
Get it on Google Play

Kontakt

Hier werben?
Oder sende eine E-Mail an

Social media u. feeds

Jobboard für Fachinformatiker und IT-Fachkräfte

×
×
  • Neu erstellen...