So funktioniert JustAnswer:
  • Fragen Sie einen Experten
    Tausende Experten in über 200 Kategorien.
  • Erhalten Sie eine professionelle Antwort
    Per E-Mail oder sofortiger Benachrichtigung, während Sie auf unserer Website warten.
    Stellen Sie ggf. weitere Anschlussfragen.
  • 100%ige Zufriedenheit garantiert
    Bewerten Sie die erhaltene Antwort.
Stellen Sie Ihre Frage an IT-Fachinformat...
IT-Fachinformatiker
IT-Fachinformatiker, Systemadministrator
Kategorie: Computer
Zufriedene Kunden: 6965
Erfahrung:  Software Entwicklung, Projekt Erfahrung, Windows-Netzwerke, Linux-Netzwerke, Windows/Linux-Server
32504664
Geben Sie Ihre Frage in der Kategorie Computer hier ein
IT-Fachinformatiker ist jetzt online.

Gesucht wird ein kl. VB6 Projekt (WIN98SE und j nger) im Quellcode

Kundenfrage

Gesucht wird ein kl. VB6 Projekt (WIN98SE und jünger) im Quellcode um FileDate (s)
auf eigenes Datum und Uhrzeit setzen zu können.
z.B.: FileDate im Explorer ist

test.jpg 15.01.11 12:33

soll geändert werden auf

test.jpg 17.01.11 13:44
Gepostet: vor 6 Jahren.
Kategorie: Computer
Experte:  IT-Fachinformatiker hat geantwortet vor 6 Jahren.
Sehr geehrter Kunde,

ich suche Ihnen die notwendigen Informationen heraus. Einen Moment bitte.

LG Günter
Experte:  IT-Fachinformatiker hat geantwortet vor 6 Jahren.
Sehr geehrter Kunde,

so ich habe Ihnen einmal folgende Beispiele gepostet. Damit sollten Sie ans Zeil kommen. Wenn Sie weitere Fragen haben, einfach antworten und, falls Sie mit der Lösung zufrieden sind würde ich mich über eine Akzeptierung freuen. Vielen Dank.

MfG Günter


Beispiel 1:

' zunächst die benötigten Deklarationen
Private Type FileTime
dwLowDateTime As Long
dwHighDateTime As Long
End Type

Private Type SYSTEMTIME
wYear As Integer
wMonth As Integer
wDayOfWeek As Integer
wDay As Integer
wHour As Integer
wMinute As Integer
wSecond As Integer
wMilliSeconds As Integer
End Type

Private Declare Function CreateFile Lib "kernel32" _
Alias "CreateFileA" ( _
ByVal lpFilename As String, _
ByVal dwDesiredAccess As Long, _
ByVal dwShareMode As Long, _
ByVal lpSecurityAttributes As Long, _
ByVal dwCreationDisposition As Long, _
ByVal dwFlagsAndAttributes As Long, _
ByVal hTemplateFile As Long) As Long
Private Declare Function CloseHandle Lib "kernel32" ( _
ByVal hObject As Long) As Long
Private Declare Function GetFileTime Lib "kernel32" ( _
ByVal hFile As Long, _
lpCreationTime As FileTime, _
lpLastAccessTime As FileTime, _
lpLastWriteTime As FileTime) As Long
Private Declare Function SetFileTime Lib "kernel32" ( _
ByVal hFile As Long, _
lpCreationTime As FileTime, _
lpLastAccessTime As FileTime, _
lpLastWriteTime As FileTime) As Long
Private Declare Function FileTimeToLocalFileTime Lib "kernel32" ( _
lpFileTime As FileTime, _
lpLocalFileTime As FileTime) As Long
Private Declare Function FileTimeToSystemTime Lib "kernel32" ( _
lpFileTime As FileTime, _
lpSystemTime As SYSTEMTIME) As Long
Private Declare Function SystemTimeToFileTime Lib "kernel32" ( _
lpSystemTime As SYSTEMTIME, _
lpFileTime As FileTime) As Long
Private Declare Function LocalFileTimeToFileTime Lib "kernel32" ( _
lpLocalFileTime As FileTime, _
lpFileTime As FileTime) As Long

Private Const GENERIC_READ = &H80000000
Private Const GENERIC_WRITE = &H40000000
Private Const OPEN_EXISTING = 3

' Die beiden nachfolgenden Routinen werden zum
' Lesen/Schreiben der Zeitangaben benötigt

Private Function ReadFileTime(ByVal sFilename As String, _
tCreation As Date, tLastAccess As Date, _
tLastWrite As Date) As Boolean
'
' *** Datum/Zeitwert einer Datei ermitteln
Dim fHandle As Long

Dim ftCreation As FileTime
Dim ftLastAccess As FileTime
Dim ftLastWrite As FileTime
Dim LocalFileTime As FileTime
Dim LocalSystemTime As SYSTEMTIME

ReadFileTime = False
fHandle = CreateFile(sFilename, GENERIC_READ, 0, 0, _
OPEN_EXISTING, 0, 0)
If fHandle <> 0 Then
' Zeitinformationen auslesen
If GetFileTime(fHandle, ftCreation, ftLastAccess, _
ftLastWrite) <> 0 Then

' Erstellungsdatum
FileTimeToLocalFileTime ftCreation, LocalFileTime
FileTimeToSystemTime LocalFileTime, LocalSystemTime
With LocalSystemTime
tCreation = CDate(Format$(.wDay) & "." & _
Format$(.wMonth) & "." & Format$(.wYear) & " " & _
Format$(.wHour) & ":" & Format$(.wMinute, "00") & _
":" & Format$(.wSecond, "00"))
End With

' Letzter Zugriff
FileTimeToLocalFileTime ftLastAccess, LocalFileTime
FileTimeToSystemTime LocalFileTime, LocalSystemTime
With LocalSystemTime
tLastAccess = CDate(Format$(.wDay) & "." & _
Format$(.wMonth) & "." & Format$(.wYear) & " " & _
Format$(.wHour) & ":" & Format$(.wMinute, "00") & _
":" & Format$(.wSecond, "00"))
End With

' Letzte Änderung
FileTimeToLocalFileTime ftLastWrite, LocalFileTime
FileTimeToSystemTime LocalFileTime, LocalSystemTime
With LocalSystemTime
tLastWrite = CDate(Format$(.wDay) & "." & _
Format$(.wMonth) & "." & Format$(.wYear) & " " & _
Format$(.wHour) & ":" & Format$(.wMinute, "00") & _
":" & Format$(.wSecond, "00"))
End With

ReadFileTime = True
End If
CloseHandle fHandle
End If
End Function

Private Function WriteFileTime(ByVal sFilename As String, _
ByVal tCreation As Date, ByVal tLastAccess As Date, _
ByVal tLastWrite As Date) As Boolean
'
' *** Datum/Zeitwert einer Datei setzen
Dim fHandle As Long

Dim ftCreation As FileTime
Dim ftLastAccess As FileTime
Dim ftLastWrite As FileTime
Dim LocalFileTime As FileTime
Dim LocalSystemTime As SYSTEMTIME

WriteFileTime = False
fHandle = CreateFile(sFilename, GENERIC_WRITE, 0, _
0, OPEN_EXISTING, 0, 0)
If fHandle <> 0 Then
' Erstellungsdatum
With LocalSystemTime
.wDay = Day(tCreation)
.wDayOfWeek = Weekday(tCreation)
.wMonth = Month(tCreation)
.wYear = Year(tCreation)
.wHour = Hour(tCreation)
.wMinute = Minute(tCreation)
.wSecond = Second(tCreation)
End With
SystemTimeToFileTime LocalSystemTime, LocalFileTime
LocalFileTimeToFileTime LocalFileTime, ftCreation

' Letzter Zugriff
With LocalSystemTime
.wDay = Day(tLastAccess)
.wDayOfWeek = Weekday(tLastAccess)
.wMonth = Month(tLastAccess)
.wYear = Year(tLastAccess)
.wHour = Hour(tLastAccess)
.wMinute = Minute(tLastAccess)
.wSecond = Second(tLastAccess)
End With
SystemTimeToFileTime LocalSystemTime, LocalFileTime
LocalFileTimeToFileTime LocalFileTime, ftLastAccess

' Letzte Änderung
With LocalSystemTime
.wDay = Day(tLastWrite)
.wDayOfWeek = Weekday(tLastWrite)
.wMonth = Month(tLastWrite)
.wYear = Year(tLastWrite)
.wHour = Hour(tLastWrite)
.wMinute = Minute(tLastWrite)
.wSecond = Second(tLastWrite)
End With
SystemTimeToFileTime LocalSystemTime, LocalFileTime
LocalFileTimeToFileTime LocalFileTime, ftLastWrite

If SetFileTime(fHandle, ftCreation, ftLastAccess, _
ftLastWrite) <> 0 Then
WriteFileTime = True
End If
CloseHandle fHandle
End If
End Function

Sub DateiAendern()
Dim tCreation As Date ' Erstellt am
Dim tLastAccess As Date ' Letzter Zugriff
Dim tLastWrite As Date ' Letzte Änderung
Dim Datei As String
Datei = "j:\01.jpg"

' Zeitangaben lesen
If ReadFileTime(Datei, tCreation, tLastAccess, tLastWrite) Then
' Erstellungsdatum ändern
tCreation = CDate("01.11.2000 17:35:41")

' Datum "Letzter Zugriff" ändern
tLastAccess = CDate("01.11.2000 17:35:41")

' Datum "Letzter Änderung" ändern
tLastWrite = CDate("01.11.2000 17:35:41")

' Zeitangaben setzen
WriteFileTime Datei, tCreation, tLastAccess, tLastWrite
End If
End Sub

Beispiel 1 als Funktion:

' zunächst die benötigten Deklarationen
Private Type FileTime
dwLowDateTime As Long
dwHighDateTime As Long
End Type

Private Type SYSTEMTIME
wYear As Integer
wMonth As Integer
wDayOfWeek As Integer
wDay As Integer
wHour As Integer
wMinute As Integer
wSecond As Integer
wMilliSeconds As Integer
End Type

Private Declare Function CreateFile Lib "kernel32" _
Alias "CreateFileA" ( _
ByVal lpFilename As String, _
ByVal dwDesiredAccess As Long, _
ByVal dwShareMode As Long, _
ByVal lpSecurityAttributes As Long, _
ByVal dwCreationDisposition As Long, _
ByVal dwFlagsAndAttributes As Long, _
ByVal hTemplateFile As Long) As Long
Private Declare Function CloseHandle Lib "kernel32" ( _
ByVal hObject As Long) As Long
Private Declare Function GetFileTime Lib "kernel32" ( _
ByVal hFile As Long, _
lpCreationTime As FileTime, _
lpLastAccessTime As FileTime, _
lpLastWriteTime As FileTime) As Long
Private Declare Function SetFileTime Lib "kernel32" ( _
ByVal hFile As Long, _
lpCreationTime As FileTime, _
lpLastAccessTime As FileTime, _
lpLastWriteTime As FileTime) As Long
Private Declare Function FileTimeToLocalFileTime Lib "kernel32" ( _
lpFileTime As FileTime, _
lpLocalFileTime As FileTime) As Long
Private Declare Function FileTimeToSystemTime Lib "kernel32" ( _
lpFileTime As FileTime, _
lpSystemTime As SYSTEMTIME) As Long
Private Declare Function SystemTimeToFileTime Lib "kernel32" ( _
lpSystemTime As SYSTEMTIME, _
lpFileTime As FileTime) As Long
Private Declare Function LocalFileTimeToFileTime Lib "kernel32" ( _
lpLocalFileTime As FileTime, _
lpFileTime As FileTime) As Long

Private Const GENERIC_READ = &H80000000
Private Const GENERIC_WRITE = &H40000000
Private Const OPEN_EXISTING = 3

' Die beiden nachfolgenden Routinen werden zum
Lesen/Schreiben der Zeitangaben benötigt
Private Function ReadFileTime(ByVal sFilename As String, _
tCreation As Date, tLastAccess As Date, _
tLastWrite As Date) As Boolean
'
' *** Datum/Zeitwert einer Datei ermitteln
Dim fHandle As Long

Dim ftCreation As FileTime
Dim ftLastAccess As FileTime
Dim ftLastWrite As FileTime
Dim LocalFileTime As FileTime
Dim LocalSystemTime As SYSTEMTIME

ReadFileTime = False
fHandle = CreateFile(sFilename, GENERIC_READ, 0, 0, _
OPEN_EXISTING, 0, 0)
If fHandle <> -1 Then
' Zeitinformationen auslesen
If GetFileTime(fHandle, ftCreation, ftLastAccess, _
ftLastWrite) <> 0 Then

' Erstellungsdatum
FileTimeToLocalFileTime ftCreation, LocalFileTime
FileTimeToSystemTime LocalFileTime, LocalSystemTime
With LocalSystemTime
tCreation = CDate(Format$(.wDay) & "." & _
Format$(.wMonth) & "." & Format$(.wYear) & " " & _
Format$(.wHour) & ":" & Format$(.wMinute, "00") & _
":" & Format$(.wSecond, "00"))
End With

' Letzter Zugriff
FileTimeToLocalFileTime ftLastAccess, LocalFileTime
FileTimeToSystemTime LocalFileTime, LocalSystemTime
With LocalSystemTime
tLastAccess = CDate(Format$(.wDay) & "." & _
Format$(.wMonth) & "." & Format$(.wYear) & " " & _
Format$(.wHour) & ":" & Format$(.wMinute, "00") & _
":" & Format$(.wSecond, "00"))
End With

' Letzte Änderung
FileTimeToLocalFileTime ftLastWrite, LocalFileTime
FileTimeToSystemTime LocalFileTime, LocalSystemTime
With LocalSystemTime
tLastWrite = CDate(Format$(.wDay) & "." & _
Format$(.wMonth) & "." & Format$(.wYear) & " " & _
Format$(.wHour) & ":" & Format$(.wMinute, "00") & _
":" & Format$(.wSecond, "00"))
End With

ReadFileTime = True
End If
CloseHandle fHandle
End If
End Function

Private Function WriteFileTime(ByVal sFilename As String, _
ByVal tCreation As Date, ByVal tLastAccess As Date, _
ByVal tLastWrite As Date) As Boolean
'
' *** Datum/Zeitwert einer Datei setzen
Dim fHandle As Long

Dim ftCreation As FileTime
Dim ftLastAccess As FileTime
Dim ftLastWrite As FileTime
Dim LocalFileTime As FileTime
Dim LocalSystemTime As SYSTEMTIME

WriteFileTime = False
fHandle = CreateFile(sFilename, GENERIC_WRITE, 0, _
0, OPEN_EXISTING, 0, 0)
If fHandle <> -1 Then
' Erstellungsdatum
With LocalSystemTime
.wDay = Day(tCreation)
.wDayOfWeek = Weekday(tCreation)
.wMonth = Month(tCreation)
.wYear = Year(tCreation)
.wHour = Hour(tCreation)
.wMinute = Minute(tCreation)
.wSecond = Second(tCreation)
End With
SystemTimeToFileTime LocalSystemTime, LocalFileTime
LocalFileTimeToFileTime LocalFileTime, ftCreation

' Letzter Zugriff
With LocalSystemTime
.wDay = Day(tLastAccess)
.wDayOfWeek = Weekday(tLastAccess)
.wMonth = Month(tLastAccess)
.wYear = Year(tLastAccess)
.wHour = Hour(tLastAccess)
.wMinute = Minute(tLastAccess)
.wSecond = Second(tLastAccess)
End With
SystemTimeToFileTime LocalSystemTime, LocalFileTime
LocalFileTimeToFileTime LocalFileTime, ftLastAccess

' Letzte Änderung
With LocalSystemTime
.wDay = Day(tLastWrite)
.wDayOfWeek = Weekday(tLastWrite)
.wMonth = Month(tLastWrite)
.wYear = Year(tLastWrite)
.wHour = Hour(tLastWrite)
.wMinute = Minute(tLastWrite)
.wSecond = Second(tLastWrite)
End With
SystemTimeToFileTime LocalSystemTime, LocalFileTime
LocalFileTimeToFileTime LocalFileTime, ftLastWrite

If SetFileTime(fHandle, ftCreation, ftLastAccess, _
ftLastWrite) <> 0 Then
WriteFileTime = True
End If
CloseHandle fHandle
End If
End Function

Aufruf der Funktionen aus dem letzten Beispiel:

Dim tCreation As Date ' Erstellt am
Dim tLastAccess As Date ' Letzter Zugriff
Dim tLastWrite As Date ' Letzte Änderung

' Zeitangaben lesen
If ReadFileTime(Datei, tCreation, tLastAccess, tLastWrite) Then
' Erstellungsdatum ändern
tCreation = CDate("01.11.2000 17:35:41")

' Datum "Letzter Zugriff" ändern
tLastAccess = CDate("01.11.2000 17:35:41")

' Datum "Letzter Änderung" ändern
tLastWrite = CDate("01.11.2000 17:35:41")

' Zeitangaben setzen
WriteFileTime Datei, tCreation, tLastAccess, tLastWrite
End If


Verändert von IT-Fachinformatiker am 17.01.2011 um 08:45 Uhr EST
Kunde: hat geantwortet vor 6 Jahren.
Wo würden Sie die
Private Type,
Private Declare
Private Const
und sonstige
'Festlegungen' empfehlen zu hinterlegen.
a) In einem Formmodul
b) in einem BAS Modul
evtl. PUBLIC

Könnten Sie das gerade mal in einer Form mit einer Datei, Cmd Button und
einen Zieldatum TextFeld bemustern?

Danke

Fritz

Beispiel 1 als Funktion:

' zunächst die benötigten Deklarationen
Private Type FileTime
dwLowDateTime As Long
dwHighDateTime As Long
End Type

Private Type SYSTEMTIME
wYear As Integer
wMonth As Integer
wDayOfWeek As Integer
wDay As Integer
wHour As Integer
wMinute As Integer
wSecond As Integer
wMilliSeconds As Integer
End Type

Private Declare Function CreateFile Lib "kernel32" _
Alias "CreateFileA" ( _
ByVal lpFilename As String, _
ByVal dwDesiredAccess As Long, _
ByVal dwShareMode As Long, _
ByVal lpSecurityAttributes As Long, _
ByVal dwCreationDisposition As Long, _
ByVal dwFlagsAndAttributes As Long, _
ByVal hTemplateFile As Long) As Long
Private Declare Function CloseHandle Lib "kernel32" ( _
ByVal hObject As Long) As Long
Private Declare Function GetFileTime Lib "kernel32" ( _
ByVal hFile As Long, _
lpCreationTime As FileTime, _
lpLastAccessTime As FileTime, _
lpLastWriteTime As FileTime) As Long
Private Declare Function SetFileTime Lib "kernel32" ( _
ByVal hFile As Long, _
lpCreationTime As FileTime, _
lpLastAccessTime As FileTime, _
lpLastWriteTime As FileTime) As Long
Private Declare Function FileTimeToLocalFileTime Lib "kernel32" ( _
lpFileTime As FileTime, _
lpLocalFileTime As FileTime) As Long
Private Declare Function FileTimeToSystemTime Lib "kernel32" ( _
lpFileTime As FileTime, _
lpSystemTime As SYSTEMTIME) As Long
Private Declare Function SystemTimeToFileTime Lib "kernel32" ( _
lpSystemTime As SYSTEMTIME, _
lpFileTime As FileTime) As Long
Private Declare Function LocalFileTimeToFileTime Lib "kernel32" ( _
lpLocalFileTime As FileTime, _
lpFileTime As FileTime) As Long

Private Const GENERIC_READ = &H80000000
Private Const GENERIC_WRITE = &H40000000
Private Const OPEN_EXISTING = 3
Experte:  IT-Fachinformatiker hat geantwortet vor 6 Jahren.
Hallo Fritz, also ich programmiere bzw. habe ja selbst in VB6 programmiert heute eher andere Sprachen, aber das ist Nebensache also der folgende Link enthält ein komplettes Projekt:

http://www.activevb.de/tipps/vb6tipps/tipp0202.html

einfach oben rechts downloaden und dann kanns schon los gehen! Wichtig, es muss das Service Pack 6 für Visual Studio 6.0 installiert werden, da hiermit auch diverse Fehler behoben werden:

http://www.microsoft.com/downloads/details.aspx?FamilyID=a8494edb-2e89-4676-a16a-5c5477cb9713&displaylang=de

Die ersten von mir geliferten Tipps muss man lediglich in ein leeres Projekt kopieren aber, das Beispiel mit der Projektdatei dürfte Sie weiter bringen, da Sie hier nur noch das ganze ggf. anpassen müssen.

LG Günter
Kunde: hat geantwortet vor 6 Jahren.
Danke für den Hinweis. Diese Stelle hatte ich schon gefunden.

Hab' mir nochmals das Projekt von denen heruntergeladen.

Leider wird bei der Textdatei das Datum nicht geändert (Im Windows Explorer).

Würde Ihnen gerne das (von mir leicht geänderte) Projekt1 als ZIP zumailen.
Vermutlich habe ich eine Kleinigkeit übersehen.

Vielleicht können Sie die Stelle ändern und mir zurücksenden

frispi at spima
Bitte lassen Sie mich wissen, wie ich Ihnen die Zip Datei zukommen lassen kann.

Gruss

Fritz Spiess (Mannheim)


PS: Die Tatsache, dass ich die Stelle bei Active VB gereits gefunden hatte hat keinerlei Einfluss auf Ihr Unterstützungshonorar !! :-))
Experte:  IT-Fachinformatiker hat geantwortet vor 6 Jahren.
Hallo,

also ich kann das leider nicht durchführen, da ich VB6 nicht mehr einsetze aber: Ich habe hier ein ganz schlichtes Beispiel, fertig und als Code speziell nur für Dateidatum inkl. Formular:

http://www.berschbach-online.de/visual-basic/projekte/windows-api-dateidatum-aendern.html

wie wäre das?

LG Günter
Experte:  IT-Fachinformatiker hat geantwortet vor 6 Jahren.
Hallo,

Hat der letzte Beispielcode das gewünschte Resultat gebracht?

LG Günter

IT-Fachinformatiker und weitere Experten für Computer sind bereit, Ihnen zu helfen.
Kunde: hat geantwortet vor 6 Jahren.
Ja alles im grünen Bereich.

Danke

Fritz Spiess

Frohes Schaffen noch
Gruss aus Mannheim Käfertal
Experte:  IT-Fachinformatiker hat geantwortet vor 6 Jahren.
Hallo, wunderbar und ich bedanke XXXXX XXXXX herzlich für die Akeptierung!

LG Günter

Ähnliche Fragen in der Kategorie Computer