![]() |
Ordner nicht leer
Hallo, ich brauche eine Funktion, die einen Ordner darauf prüft ob er Dateien hat. Also wenn er andere Ordner beinhaltet, soll die Funktion false zurückgeben. Darauf hin habe ich diese funktion hier gefunden.
Code:
//returns true if a given directory is empty, false otherwise
function IsDirectoryEmpty(const directory : string) : boolean; var searchRec :TSearchRec; begin try result := (FindFirst(directory+'\*.*', faAnyFile, searchRec) = 0) AND (FindNext(searchRec) = 0) AND (FindNext(searchRec) 0) ; finally FindClose(searchRec) ; end; end; ![]() aber mein delphi 6 kann es nicht kompilieren, es sagt (FindNext(searchRec) 0) da fehlt ein semikolon?? |
AW: Ordner nicht leer
Vor der "0" fehlt "<>".
Hier ein , finde ich, besserer ![]()
Delphi-Quellcode:
// Diese Funktion gibt true zurück, falls Directory ein leeres Verzeichnis ist.
// This function returns true if Directory is an empty directory. function DirectoryIsEmpty(Directory: string): Boolean; var SR: TSearchRec; i: Integer; begin Result := False; FindFirst(IncludeTrailingPathDelimiter(Directory) + '*', faAnyFile, SR); for i := 1 to 2 do if (SR.Name = '.') or (SR.Name = '..') then Result := FindNext(SR) <> 0; FindClose(SR); end; // Beispiel: // Example: procedure TForm1.Button1Click(Sender: TObject); begin if DirectoryIsEmpty('C:\test') then Label1.Caption := 'empty' else Label1.Caption := 'not empty'; end; |
AW: Ordner nicht leer
Hallo KodeZwerg,
leider bekomme ich "nicht leer", also false, wenn in dem Ordner andere Ordner drin sind. |
AW: Ordner nicht leer
Wenn Unterverzeichnisse enthalten sind, ist das Haupt-Verzeichniss nicht leer, also ist Dein beschriebener Rückgabewert korrekt.
Man kann diese Funktion erweitern indem man, das muss dann leider sein, noch alle gefundendene Elemente auf sein Attribut abgleicht. (dauert halt länger) Nur hier im Editor schnell mal was zusammengepopelt.... ungetestet...
Delphi-Quellcode:
function CheckIfFilesInPath(const Path: string): Boolean;
var SR: TSearchRec; begin Result := False; if FindFirst(Path + '*.*', faAnyFile, SR) = 0 then begin repeat if (SR.Attr <> faDirectory) then begin Result := True; Break; end; until FindNext(SR) <> 0; FindClose(SR); end; end; So könnte was draus werden... teste mal und viel glück :-) |
AW: Ordner nicht leer
Da fehlt ein
Delphi-Quellcode:
.
=
Tipp: Vergleich es mal mit der Zeile darüber. :zwinker: Allerdings ist das etwas wage, denn die Funktion geht "blind" davon aus dass es . und .. gibt, also ab mindestens 3 "Einträgen" existiert mindestens eine Datei (könnte aber auch ein Verzeichnis sein). Besser ist es in einer "normalen" suchschleife durchzulaufen, vor Variable(n) auf False zu setzen, die Dateien . und .. zu ignorieren, und dann jeweils die Attribute zu prüfen (Datei oder Verzeichnis) und entsprechend die Variable(n) auf True zu setzen. Ist/Sind die Variable(n) auf True, kann die Schleife vorzeitig abgebrochen werden. (Das Ergebnis steht ja schon fest) [edit] siehe KodeZwerg |
AW: Ordner nicht leer
Hallo,
es ist ratsam, anstelle von
Delphi-Quellcode:
einen qualifizierten Bezeichner
FindClose(SR);
Delphi-Quellcode:
zu verwenden, weil es u. U. Konflikt geben kann mit der gleichnamigen Procedure
System.SysUtils.FindClose(SR);
Delphi-Quellcode:
, die allerdings einen anderen Datentyp erwartet.
WinAPI.Windows.FindClose(SR);
Gruß, Andreas |
AW: Ordner nicht leer
Ist es gut so?
Code:
@Andreas13
function TForm1.CheckIfFilesInPath(const Path: string): Boolean;
var MySearch: TSearchRec; FindResult: Integer; begin result := false; FindResult:=FindFirst(Path+'\*.*', faAnyFile, MySearch); while (FindResult = 0) do begin if (MySearch.Name<>'.') and (MySearch.Name<>'..') and (MySearch.Attr <> faDirectory) then begin result := true; break; end; FindResult := FindNext(MySearch); end; FindClose(MySearch); end; das konnte ich so nicht kompilieren, ich bekomme den Fehler
Code:
das habe ich bei den Uses aber angebunden. Vielleicht liegt es aber an meinem uralten Delphi 6
[Fehler] trash.pas(213): Undefinierter Bezeichner: 'SysUtils'
|
AW: Ordner nicht leer
Kein Problem: Wahrscheinlich hat Delphi 6 auch noch kein WinAPI.Windows, so daß es dort (noch) keinen Konflikt geben kann.
Andreas |
AW: Ordner nicht leer
Anderer Vorschlag:
Delphi-Quellcode:
function DirContainsFiles(const Dirname: string): Boolean;
var Rec: TSearchRec; SearchPattern: string; begin Result := false; SearchPattern := IncludeTrailingBackslash(Dirname) + '*.*'; if FindFirst(SearchPattern, faAnyFile, Rec) = 0 then try repeat if Rec.Attr and faDirectory = 0 then Result := true; until (FindNext(Rec) <> 0) or Result; finally SysUtils.FindClose(Rec); end; end; |
AW: Ordner nicht leer
Hallo Deddyh! Könntest du bitte die Zeile hier erklären`?
Code:
if Rec.Attr and faDirectory = 0 then
|
AW: Ordner nicht leer
Damit wird geprüft, ob die Bitmaske der Dateiattribute das Flag faDirectory enthält. Wenn ja, ist es ein Verzeichnis.
|
AW: Ordner nicht leer
in Rec ist eine Datei (Verzeichniss-Attribut ist nicht gesetzt)
|
AW: Ordner nicht leer
Also lese ich das so richtig? Rec.Attr ist ein Integer und nicht null und faDirectory ist aber gleich null, dann ist es ein Ordner? Also kann man generell die Konstanten der FindFirt Funktion mit = 0 abfragen?
|
AW: Ordner nicht leer
Zitat:
Zitat:
einfach auf 0 prüfen ist der falsche weg. funktionieren denn die beispiele nicht? was für probleme haben die beispiele? |
AW: Ordner nicht leer
Wieso ist das der falsche Weg? Exakt auf faDirectory zu prüfen wäre definitiv falsch, da auch andere Attribute enthalten sein können. Zur Erklärung:
![]() |
AW: Ordner nicht leer
Zitat:
|
AW: Ordner nicht leer
In dem Moment, wo ein Unterverzeichnis z.B. das Archiv-Attribut gesetzt hat, funktioniert die exakte Prüfung nicht mehr, d.h. das Verzeichnis wird als Datei erkannt.
|
AW: Ordner nicht leer
hehe, warste schneller als ich :-) das wollte ich damit, ohne ausführlich zu werden, sagen.
//edit vielleicht hilft dir das hier kagi3624 -> ![]() hat jetzt nicht direkt was mit bitmasken zu tun aber da las ich auch vorhin ne frage die der link vielleicht ausführlicher beantwortet, um hinter der logik von delphi ein wenig durchzuschauen. |
AW: Ordner nicht leer
Hallo Kagi3624,
darf ich Dir zwei exzellente Fachbücher zu Deinem Delphi 6 empfehlen? Walter Doberenz und Thomas Kowalski: 1): Borland Delphi 6. Grundlagen und Profiwissen ![]() 2): Borland Delphi 6 Kochbuch ![]() Dort findest Du eine sehr gute Einführung in Delphi 6, u. a. auch in das Thema "Bitweise Operationen": --> Band 2: "Einen Wert auf Bit-Ebene manipulieren" Gruß, Andreas |
AW: Ordner nicht leer
Ok, um zu testen, ob ich es verstanden habe, habe ich die Suchfunktion abgewandelt um alle Dateinamen ohne die Unterordner in ein Memofeld zu schreibeiben.
Code:
Es funktioniert auch. Ich frage mich bloß, wieso man in diesem Fall nicht nach den '.' und '..' suchen muss.
function TForm1.DirContainsFiles(const Dirname: string): Boolean;
var Rec: TSearchRec; SearchPattern: string; begin Memo3.Text := ''; Result := false; SearchPattern := IncludeTrailingPathDelimiter(Dirname) + '*.*'; if FindFirst(SearchPattern, faAnyFile, Rec) = 0 then try repeat if Rec.Attr and faDirectory = 0 then begin Result := true; Memo3.Lines.Add(Rec.Name); end; until (FindNext(Rec) <> 0); finally SysUtils.FindClose(Rec); end; end; |
AW: Ordner nicht leer
Weil '.' für das aktuelle und '..' für das übergeordnete Verzeichnis steht, es sind also Verzeichnisse. Daher ist das Flag gesetzt und der Vergleich ergibt nicht 0, sondern faDirectory. Hast Du mein Tutorial schon gelesen, das ich weiter oben verlinkt hatte?
|
AW: Ordner nicht leer
Jemand könnte für die Attribute mal auf die blöde Idee kommen das in ein SET zu ändern, dann kann man schön ein IN benutzen.
Gut, dann kompilieren viele Codes nicht mehr, aber man kann sich auch gern einen ClassOperator für diesen Vergleich erstellen, damit man bei diesem Integer auch das IN benutzen kann.
Delphi-Quellcode:
:angle:
if faDirectory in Rec.Attr then begin
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 11:21 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz