![]() |
Delphi-Version: 10.4 Sydney
SysUtils.DirectoryExists
Liste der Anhänge anzeigen (Anzahl: 2)
Moin,
ich bekomme bei
Delphi-Quellcode:
einen Fehler den ich nicht verstehe:
SysUtils.DirectoryExists
Delphi-Quellcode:
Arbeitsverzeichnis ist in der Ini-Datei definiert und (zumindestens für mich) sieht das auch so aus als ob das Verzeichnis existiert. Sieht irgendjemand warum Delphi trotzdem die Meldung zeigt ?
if not SysUtils.DirectoryExists(ArbeitsVerzeichnis +'\') then
begin ShowMessage('Falsches Verzeichnis im INI-String !' +#13 +'Programm wird beendet'); end; In der Anlage ist einmal die INI-Datei und einmal der Ausschnitt aus dem Explorer. Gruss Hans |
AW: SysUtils.DirectoryExists
Was steht denn in der Variable Arbeitsverzeichnis wenn Du Dir das mal mit dem Debugger ansiehst? Oder/und gib im "Fehlerfall" das nicht gefundene Verzeichnis in die Ausgabe mit.
|
AW: SysUtils.DirectoryExists
Zitat:
Außerdem: Du hast doch einen Debugger. Schau doch zur Laufzeit einfach, was in der Variable drinsteht. |
AW: SysUtils.DirectoryExists
Mache es doch einfach mal so, um zu sehen was da im Arbeitsverzeichnis steht:
Code:
if not SysUtils.DirectoryExists(ArbeitsVerzeichnis +'\') then begin
// ShowMessage('Falsches Verzeichnis im INI-String !' +#13 +'Programm wird beendet'); ShowMessage(Arbeitsverzeichnis); end; |
AW: SysUtils.DirectoryExists
Ich sehe im Explorer ein Leerzeichen zwischen "AA" und "Zauner".
|
AW: SysUtils.DirectoryExists
Zitat:
|
AW: SysUtils.DirectoryExists
Zitat:
|
AW: SysUtils.DirectoryExists
[edit] ups, den letzten übersehn [/edit]
Wozu denn das +'\' ? Eher #10 statt #13, oder besser noch ![]() Zitat:
Und ja, siehe Antwort #5. |
AW: SysUtils.DirectoryExists
Pfade, die man kopieren kann, niemals abtippen. Das spart so viel Ärger (und meistens auch noch Zeit...).
|
AW: SysUtils.DirectoryExists
Wenn ich "\" am Ende des Pfades brauche, dann würde ich das mittels der Funktion IncludeTrailingPathDelimiter hinzufügen.
|
AW: SysUtils.DirectoryExists
Zitat:
Delphi-Quellcode:
mittels
A + '\' + B
Delphi-Quellcode:
.
TPath.Combine(A, B)
|
AW: SysUtils.DirectoryExists
Zitat:
Das mit der Ausgabe des Fehlers ist ne Idee - das teste ich mal aus. Danke Hans |
AW: SysUtils.DirectoryExists
Zitat:
also c:\test\abc -> Datei c:\test\abc\ -> Pfad ich weiß nicht ob das evtl. sogar mal so war - auf alle Fälle klapt bei SysUtils.DirectoryExists beides. Gruss Hans |
AW: SysUtils.DirectoryExists
Zitat:
Hans |
AW: SysUtils.DirectoryExists
Es kann gehn, aber muß nicht.
C:\ ist auch was Anderes als C:\test\ Denn C: ist relativ zum aktuellen Arbeitsverzeichnis dieses Laufwerks. Ja, der Syntax nach könnte man es so sehn c:\test\abc -> Datei oder Verzeichnis (je nach Attribut) c:\test\abc -> Directory c:\test\abc\ -> Path c:\test\abc\. -> ParentDirecrory to Self Achtung: ![]() TFile.Exists aber nur auf Datei -> TDirectory.Exists für Verzeichnis |
AW: SysUtils.DirectoryExists
Oder wenn man es ohne SysUtils in sehr kleinen non-Vcl Anwendungen braucht kann man auch
Code:
das machen.
function DirectoryExists(const FilePath: string): Boolean;
var Attr: Cardinal; begin Attr := GetFileAttributes(PChar(FilePath)); Result := (Attr <> $FFFFFFFF) and (Attr and FILE_ATTRIBUTE_DIRECTORY <> 0); end; |
AW: SysUtils.DirectoryExists
Zitat:
|
AW: SysUtils.DirectoryExists
Zitat:
|
AW: SysUtils.DirectoryExists
Nee, tut es nicht, außer B endet mit einem "\".
Himitsu ging davon aus, dass du den "\" anhängen willst, weil danach noch ein weiterer Pfadbestandteil folgen soll. Du willst es aber, um dem System deutlich zu machen, dass du ein Verzeichnis meinst und nicht eine Datei. Das konnte Himitsu nicht wissen. |
AW: SysUtils.DirectoryExists
Nee, genauso wie man zum Anhängen oder Entfernen eine Funktion hat,
gibt es seit einer kürzeren Weile auch eine Funktion für das Zusammenbauen. Selbst manuell gebaut kommt es noch besser, wenn man die Konstante benutzt, anstatt dem selbstgeschriebenen. Windows entfernt überzählige Trenner, wie z.B. den Letzten im Pfad (aber nie den Ersten, also den nach einem :) oder Doppelte mittendrin. Denn der Erste folgt nicht auf das X: sondern leitet den "absoluten" Pfad innerhalb des Laufwerks ein. Linux, Mac oder Android reagieren dagegen allergischer auf "Mist". Ein Pfad Endet niemals mit einem. Der Pfad, bzw. das Verzeichnis, ist der "letzte" Name. (Unterschied macht ausschließlich das Dateiattribut) Bei "Pfaden" hatte sich nur Einfas eingebürgert, aber leider ist es keine Vorschrift. z.B. * TempFile ist ein temporärer Dateiname, aber nicht gesagt ob mit oder ohne Verzeichnis * TempDir ist das temporäre Verzeichnis, ohne \ * TempPath ist das temporäre Verzeichnis mit \ , damit man direkt einen Dateinamen anhängen kann |
AW: SysUtils.DirectoryExists
Die API
Delphi-Quellcode:
und damit auch
DeleteFile
Delphi-Quellcode:
funktionieren sogar nicht, wenn ein "\" am Ende steht.
TDirectory.Delete
Ich muss aber auch gestehen, dass ich ein Verzeichnis meist mit "\" abschließe. Ich meine, das kommt noch aus den DOS-Zeiten, als der Prompt manchmal nachfragte, ob man eine Datei oder ein Verzeichnis meint. |
AW: SysUtils.DirectoryExists
Im FinalBuilder nehme ich auch manchmal \
Es gibt Funktionen, die Dateien und/oder Verzeichnisse löschen. Bzw. in Acktionen zum Kopieren von Einzeldateien. * mehrere Dateien (also inkl. Maske) da ist das Ziel immer das Verzeichnis * bei Einzeldatei ist es mit \ immer ein Verzeichnis und der Dateiname wird beibehalten * bei Einzeldatei ohne \ im Ziel muß man aufpassen unten die Checkbox nicht zu vergessen * * dort kann das Ziel als "Kopieren mit neuem Namen" angesehn werden |
Alle Zeitangaben in WEZ +1. Es ist jetzt 12:41 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