Top-Themen

AppleEntwicklungHardwareInternetLinuxMicrosoftMultimediaNetzwerkeOff TopicSicherheitSonstige SystemeVirtualisierungWeiterbildungZusammenarbeit

Aktuelle Themen

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit
GELÖST

Dateigrössen vergleichen

Frage Entwicklung VB for Applications

Mitglied: idkfa2k7

idkfa2k7 (Level 1) - Jetzt verbinden

29.02.2008, aktualisiert 15:05 Uhr, 3906 Aufrufe, 3 Kommentare

Programmsprache VBS

Hi Leute,
ich armer Systemtechniker verzweifle an dieser Aufgabe...

Folgendes:
Mir werden Täglich die DHCP Files in einen Ordner als .txt Dateien exportiert. Dieser Vorgang geht ab und zu schief, d.h
Normalerweise unterscheiden sich die Files um wenige KB + - 5. Wenn der Vorgang jedoch schief geht dann unterscheiden sich die Dateien
um mehrere KB + - 50KB.

Ich habe das Ganze programmiert, aber ich schaffe es nicht alle Bedingungen zu berücksichtigen.
Leider funktioniert mein Skript nicht, wenn die neue Datei 50Kb grösser als die alte Datei ist, wie kann ich das auch noch filtern? Programmiert habe ich es mit VBS


' Name: delte_dhcp_error.vbs
' Author: idkfa2k7
' Version: 2.0

Option Explicit

Dim varPos,sizeOld, sizeNew, diffOldNew, diffOldNewNeg
Dim fileOld, fileNew, fileCopy
Dim fso, file, objfs

Const ForReading = 1


' in Bytes. Tolleranz Grössendifferenz der letzten 2 Tagesfiles (Dient zur Sicherung von Fehlexporten)
varPos = 50*1024

' Berechnung von Diffenrenz diffOldNew (altem und neuem File)
Set fso = CreateObject("Scripting.FileSystemObject")
Set file = fso.GetFile("C:\Temp\export\dhcp_sav" & Date()-1 & ".txt")
sizeOld = file.Size
Set file = fso.GetFile("C:\Temp\export\dhcp_sav" & Date() & ".txt")
sizeNew = file.Size
Set file = Nothing
Set fso = Nothing

diffOldNew = sizeOld - sizeNew

'Dies sind die Dateien welche in die lokale Datei gespeichert wird
fileOld = "C:\Temp\export\dhcp_sav" & Date()-1 & ".txt"
fileNew = "C:\Temp\export\dhcp_sav" & Date() & ".txt"
fileCopy = "C:\Temp\dhcp_imp.txt"

'Überprüft ob das Filedelta kleiner, grösser oder gleich, dann wirder Import über aktuelle Datei ausgeführt_
'ansonsten wird die Version vom Tag zuvor genmommen
If diffOldNew <= varPos Then
Set objfs = CreateObject("Scripting.FileSystemObject")
objfs.CopyFile fileNew, fileCopy, True
MsgBox("Es wurde eine Kopie von heute erstellt")
Else
Set objfs = CreateObject("Scripting.FileSystemObject")
objfs.CopyFile fileOld, fileCopy, True
MsgBox("Es wurde die Kopie vom Tag zuvor verwendet")
End If



Danke für eure Hilfe
Mitglied: Korrn
29.02.2008 um 09:33 Uhr
Kleiner Logik-Fehler:
diffOldNew = sizeOld - sizeNew
Wenn die neue Datei größer ist, als die alte, dann bekommst Du einen negativen Wert, durch den
diffOldNew <= varPos
immer true ist.

Kenn mich nicht so sehr mit VB aus, Du brauchst entweder eine Funktion, die Dir den Betrag von diffOldNew zurück gibt, oder Du umgehst es mit:

diffOldNew = sizeOld - sizeNew
if diffOldNew < 0 Then
diffOldNew = diffOldNew * 1
End If
Bitte warten ..
Mitglied: idkfa2k7
29.02.2008 um 09:50 Uhr
Danke für die schnelle Hilfe!!! Erleichterung macht sich breit, und es ist auch noch Freitag ;)
Jedoch ist es notwenig * -1 zu machen, da sonnst die Zahl ja nicht invertiert wird.

diffOldNew = sizeOld - sizeNew
if diffOldNew < 0 Then
diffOldNew = diffOldNew * -1
End If
Bitte warten ..
Mitglied: bastla
29.02.2008 um 15:05 Uhr
Hallo idkfa2k7 und Korrn#!

Eigentlich genügt:
01.
diffOldNew = Abs(sizeOld - sizeNew)
Grüße
bastla

P.S.: Es werden hier auch <code>-Tags unterstützt ...
Bitte warten ..
Ähnliche Inhalte
Microsoft Office
gelöst Excel: Wert aus mehreren Zeilen vergleichen (2)

Frage von Nicolaas zum Thema Microsoft Office ...

Batch & Shell
gelöst AD Usernamen in CSV Vergleichen (32)

Frage von Hainoon zum Thema Batch & Shell ...

Batch & Shell
gelöst Auslesen und Vergleichen Zweiter CSV Dateien Powershell (7)

Frage von Hainoon zum Thema Batch & Shell ...

Neue Wissensbeiträge
Windows 10

Windows 8.x oder 10 Lizenz-Key aus dem ROM auslesen mit Linux

(6)

Tipp von Lochkartenstanzer zum Thema Windows 10 ...

Tipps & Tricks

Wie Hackt man sich am besten in ein Computernetzwerk ein

(40)

Erfahrungsbericht von Herbrich19 zum Thema Tipps & Tricks ...

Heiß diskutierte Inhalte
Windows 10
gelöst Windows 10 Home "Netzlaufwerk nicht bereit" (19)

Frage von Oggy01 zum Thema Windows 10 ...

Exchange Server
gelöst RU 17 Exchange 2010 . Erfahrungen? (10)

Frage von keine-ahnung zum Thema Exchange Server ...

Datenbanken
gelöst MySQL Zeiterfassungs-Problematik (wer ist eingecheckt) (9)

Frage von NativeMode zum Thema Datenbanken ...

Windows Server
Festplatten Ruhezustand Windows Server 2016 (8)

Frage von ahaeuser zum Thema Windows Server ...