Top-Themen

Aktuelle Themen (A bis Z)

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

Vergleich von zwei CSV-Dateien und Schreiben der Änderungen in eine dritte CSV-Datei

Frage Entwicklung Batch & Shell

Mitglied: knobi

knobi (Level 1) - Jetzt verbinden

27.01.2006, aktualisiert 21.04.2006, 17744 Aufrufe, 5 Kommentare

Hallo User

Ich arbeite auf Windows XP. Nun möchte ich zwei CSV Dateien zeilenweise miteinander vergleichen, wobei nur die geänderten Zeilen in Datei 2 (gegenüber Datei 1) in eine separate dritte CSV-Datei geschrieben werden. Datei 3 soll dann nur die geänderten Zeilen aus Datei 2 enthalten.
Der Dateivergleich über fc bringt mir nicht das gewünschte Ergebnis.
Sicher lässt sich eine Lösung über eine Batchdatei oder ein geeignetes Tool finden?
Könnt ihr mir Tips geben oder Lösungsmöglichkeiten?
Vielen Dank im Vorraus

Knobi
Mitglied: gooogix
27.01.2006 um 14:34 Uhr
Hallo!

Ich benutze für CSV-Dateien oft das Tool CSVed:

http://home.hccnet.nl/s.j.francke/t2t/text2table.htm

Evtl. hilft Dir das bei der Lösung.

Gruss
Udo
Bitte warten ..
Mitglied: netstorm
27.01.2006 um 15:37 Uhr
Hallo,

unter Linux würde ich sowas mit Perl oder diff machen. Beides gibt es auch für Windows.

Bei Perl mußt Du noch ein passendes Script schreiben. Diff ist ein Package, daß sich eben genau um das Vergleichen von Dateien kümmert. In deinem Fall wäre also diff sicher die passendere Lösung. Schau also mal unter: http://gnuwin32.sourceforge.net/packages/diffutils.htm

Solltest Du doch Interesse an Perl haben, sag einfach nochmal bescheid. Ansonsten kannst du dir auch mal diesen Thread anschauen: Hat zwar nix mit deinem konkreten Problem zu tun, aber da kannste mal gucken wie ein Perlscript aussieht: http://www.administrator.de/aus_Textseite_bestimmte_Zeile_herrauskopier ...

CIAO Thorsten
Bitte warten ..
Mitglied: maneich
28.01.2006 um 12:09 Uhr
Hallo,

mit einem VBS sollte das auch klappen:

---------------------------------snip!!
Set fs =CreateObject("Scripting.FileSystemObject")
Set f1 = OpenTextFile("Pfad\csv1.csv")
Set f2 = OpenTextFile("Pfad\csv2.csv")
Set f3 = OpenTextFile("Pfad\scv3.csv", 2, True)
do
da1 = f1.ReadLine
da2 = f2.ReadLine
x1 = StrComp(da1, da2, 0) '0 = binärer- / 1 = text-Vergleich = testen was für Dich besser ist
If x1 <> 0 Then
f3.WriteLine da2
End If
Loop Until f1.AtEndOfStream
f1.Close
f2.Close
f3.Close
WScript.Quit
--------------------------------snap!!

wenn Datei f2 mehr Zeilen haben kann als f1 mußt Du eben unter Loop noch einfügen

do
f3.WriteLine f2.ReadLine
Loop Until f2.AtEndOf Stream

MfG maneich
Bitte warten ..
Mitglied: knobi
30.01.2006 um 15:47 Uhr
Hallo Udo,

Danke für den Tip. Habe das Tool installiert.
Allerdings weigerte sich CSVed die CSV-Datei zu öffnen, weil sie angeblich leer ist, was natürlich nicht der Fall ist.

Im Tool habe ich aber auch noch keine Einstellung gesehen, wo ich zwei CSV-Dateien vergleichen kann.

Trotzdem Danke für den Tip. Bestimmt kann ich das Tool mal an anderer Stelle brauchen.

Gruß Knobi
Bitte warten ..
Mitglied: paed
21.04.2006 um 11:24 Uhr
Hi,

Bei Perl mußt Du noch ein passendes
Script schreiben. Diff ist ein Package,
daß sich eben genau um das Vergleichen
von Dateien kümmert.
das gibt's schon, schau dir mal http://csvdiff.sourceforge.net/ an. Du kannst bei csv diff (mehrere) Key-Spalten angeben, Gross/Kleinschreibung ignorieren, fuehrenden oder nachlaufende Leerzeichen ignorieren, oder geziehlt Spalten fuer den Vergleich ausblenden. Das Ausblenden ist z.B. fuer Spalten gut, die dich "eh nicht interessieren" (z.B. Timestamps), so prodozieren diese Spalten keine "unnuetzen" Meldungen, das sich dieser Datensatz veraendert hat.

In deinem Fall
wäre also diff sicher die passendere
Lösung. Schau also mal unter:
http://gnuwin32.sourceforge.net/packages/diffutils.htm
Das sehe ich anders.
Diff hat nur wenig zu bieten was die Syncronisation angeht, wenn in einer der Dateien (viele) Zeilen hinzukommen, wegfallen oder sich aendern, wird's haarig. Das Ergebnis wird auch schnell unbrauchbar, wenn die Reihenfolge der Datensaetze in den Dateien unterschiedlich ist. Dann kommt diff schnell "aus dem Tritt". Ausserdem Weisst du so nur welche Zeile(n) sich unterscheiden. Wenn die Zeile "sehr lang" ist bzw. viele Felder enthaelt, ist es schoener wenn dir gleich die Stelle praesentiert wird, die unterschiedlich ist, oder?


Viel Erfolg

Paed
Bitte warten ..
Ähnliche Inhalte
Batch & Shell
CSV Dateien vergleichen die Hundertse
gelöst Frage von hansbaerBatch & Shell4 Kommentare

Hiho, ich bin der totale Noob was das angeht, aber ich möchte in einer batch zwei csv Dateien mit ...

Batch & Shell
Auslesen und Vergleichen Zweiter CSV Dateien Powershell
gelöst Frage von HainoonBatch & Shell7 Kommentare

Hallo zusammen, ich arbeite im Moment an einem Script zum auslesen und vergleichen von Usern in der AD. Das ...

Batch & Shell
AD User mit CSV Datei Vergleichen und Webseite befüllen
gelöst Frage von IT-WurzelBatch & Shell11 Kommentare

Hallo liebe Community, ich sehe schon den Wald vor lauter Bäumen nicht mehr habe mir nach einigen Anregungen hier ...

Outlook & Mail
CSV Datei exportieren
gelöst Frage von 117109Outlook & Mail1 Kommentar

Hallo Leute, mal eine Frage. Und zwar aus einer Ecel Datei wurde eine CSV Datei mit Kontaktenerstellt. Diese wurde ...

Neue Wissensbeiträge
Internet

EU-DSGVO: WHOIS soll weniger Informationen liefern

Information von sabines vor 8 StundenInternet3 Kommentare

Wegen der europäische Datenschutzgrundverordnung stehen die Prozesse um die Registierunf von Domains auf dem Prüfstand. Sollte die Forderungen umgesetzt ...

Verschlüsselung & Zertifikate

19 Jahre alter Angriff auf TLS funktioniert immer noch

Information von BassFishFox vor 15 StundenVerschlüsselung & Zertifikate1 Kommentar

Interessant zu lesen. Der Bleichenbacher-Angriff gilt unter Kryptographen als Klassiker, trotzdem funktioniert er oft noch. Wie wir herausgefunden haben, ...

Windows 10

Windows 10 Fall Creators Update - Neue Funktion Hyper-V Standardswitch kann ggf. Fehler bei Proxy Configs verursachen

Erfahrungsbericht von rzlbrnft vor 1 TagWindows 104 Kommentare

Hallo Kollegen, Da wir die Gefahr lieben, haben wir bei einigen Usern nun mittlerweile das Creators Update drauf. Einige ...

Sicherheit

TLS-Zertifikat und privater Schlüssel von Microsofts Dynamics 365 geleakt

Information von Penny.Cilin vor 1 TagSicherheit

Microsoft hat versehentlich das TLS-Zertifikat inklusive dem privaten Schlüssel seiner Business-Anwendung Dynamics 365 geleakt. TLS-Zertifikat und privater Schlüssel von ...

Heiß diskutierte Inhalte
LAN, WAN, Wireless
Von rj11 auf rj45
Frage von jensgebkenLAN, WAN, Wireless18 Kommentare

Hallo Gemeinschaft, könnt ihr mir vielleicht bei der anfertigung eines Kabels helfen - habe ein rj 11 stecker und ...

Netzwerkmanagement
Firefox Profieles im Roaming
gelöst Frage von Hendrik2586Netzwerkmanagement17 Kommentare

Hallo liebe Leute. :) Ich hab da ein kleines Problem, welches anscheinend nicht unbekannt ist. Wir nutzen hier in ...

Netzwerkmanagement
NAS über zwei weitere Ethernet Anschlüsse verbinden
gelöst Frage von Sibelius001Netzwerkmanagement17 Kommentare

Sorry - ich bin hier wahrscheinlich als kompetter IT Trottel unterwegs. Aber eventuell kann mir jemand ganz einfach helfen: ...

LAN, WAN, Wireless
Häufig Probleme beim Anmelden in WLAN
Frage von mabue88LAN, WAN, Wireless15 Kommentare

Hallo zusammen, in einem Netzwerk gibt es relativ häufig (1-2 mal pro Woche) Probleme mit der WLAN-Verbindung. Zunächst mal ...