AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren

Vergleich Eingabe Edit-Feld mit Excelfeld

Ein Thema von Sanni13 · begonnen am 30. Dez 2015 · letzter Beitrag vom 30. Dez 2015
Antwort Antwort
Sanni13
(Gast)

n/a Beiträge
 
#1

Vergleich Eingabe Edit-Feld mit Excelfeld

  Alt 30. Dez 2015, 15:54
Hallo,

ich möchte gern herausfinden, ob eine Eingabe bereits in einer zugewiesenen Exceltabelle vorhanden ist. Dazu habe ich folgenden Quelltext geschrieben:
Delphi-Quellcode:
var Excel: OleVariant;
    i, MaxRow:Integer;
begin
  try
   Excel := CreateOleObject('Excel.Application');
  except
   ShowMessage('Excel konnte nicht gestartet werden !');
   Exit;
  end;
  Excel.Workbooks.Open('C:\Users\Programm.xls');
  Excel.Visible := true;
  MaxRow := Excel.Rows.Count;
  for i:=1 to MaxRow do
    if Edit1.Text=Excel.Cells.Item[i,1].Value then
      ShowMessage('wird in der Datei verwendet');
end;
Das Programm lässt sich starten, zeigt mir jedoch in der Ausführung den Fehler: "Press ok to risk data corruption. Press cancel to kill the program" an. Außerdem wird auch die Nachricht nicht angezeigt, wenn der eingegebene Text in Edit1 mit dem in einer Zelle übereinstimmt. Sehe leider den Fehler nicht und hoffe ihr könnt mir helfen!
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#2

AW: Vergleich Eingabe Edit-Feld mit Excelfeld

  Alt 30. Dez 2015, 16:09
Bist du sicher, dass Excel die Zeilen mit 1 anfängt zu zählen? Und nicht mit 0 wie üblich? Und was hast du beim Debuggen rausgefunden? Bist du das ganze mal in Einzelschritten durch gegangen?
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Jumpy

Registriert seit: 9. Dez 2010
Ort: Mönchengladbach
1.733 Beiträge
 
Delphi 6 Enterprise
 
#3

AW: Vergleich Eingabe Edit-Feld mit Excelfeld

  Alt 30. Dez 2015, 16:23
Versuch es mal so mit ActiveSheet:

Delphi-Quellcode:
var Excel: OleVariant;
    i, MaxRow:Integer;
begin
  try
   Excel := CreateOleObject('Excel.Application');
  except
   ShowMessage('Excel konnte nicht gestartet werden !');
   Exit;
  end;
  Excel.Workbooks.Open('C:\Users\Programm.xls');
  Excel.Visible := true;
  MaxRow := Excel.ActiveSheet.UsedRange.Rows.Count; //hier
  for i:=1 to MaxRow do
    if Edit1.Text=Excel.ActiveSheet.Cells[i,1].Value then //und hier
      ShowMessage('wird in der Datei verwendet');

  //Jetzt auch noch mal ein bißchen aufräumen:
  Excel.ActiveWorkbook.Close(False);
  Excel.Quit; //?
  Excel:=Nothing/nil // k.A. wie das bei OleVariants nochmal genau ging
end;
Ansonsten nochmal mit zusätzlichen Variablen für Workbook und Worksheet versuchen, dann kann man besser debuggen.
Ralph
  Mit Zitat antworten Zitat
Benutzerbild von Chemiker
Chemiker

Registriert seit: 14. Aug 2005
1.858 Beiträge
 
Delphi 11 Alexandria
 
#4

AW: Vergleich Eingabe Edit-Feld mit Excelfeld

  Alt 30. Dez 2015, 19:51
Hallo Sanni13,

Der Ausdruck:

if Edit1.Text=Excel.Cells.Item[i,1].Value then
ist problematisch, wenn in der Excel Zelle z.B. eine Zahl oder Datum steht, wird es zu einer Fehlermeldung kommen.

Des weiteren ist die Verarbeitung sehr langsam, weil die Schleife bis zur letzten Zeile von Excel durchgeführt wird.

Bis bald Chemiker
wer gesund ist hat 1000 wünsche wer krank ist nur einen.
  Mit Zitat antworten Zitat
Themen-Optionen Thema durchsuchen
Thema durchsuchen:

Erweiterte Suche
Ansicht

Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 00:06 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz