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

Wie kann ich via Batch eine Datumsspalte in eine CSV Datei einfügen?

Mitglied: BBUser

BBUser (Level 1) - Jetzt verbinden

01.04.2010, aktualisiert 12:25 Uhr, 4164 Aufrufe, 7 Kommentare

Auf diversen Servern fallen täglich Logfiles an, welche in Excel in einer Pivot ausgewertet werden sollen.

Hallo Forum,

die o.g. Logfiles werden mittels eines Herstellereigenen Tools ausgewertet. Es wird eine CSV generiert. In diese CSV Datei möchte ich nun vorzugweise mittels einer BATCH Datei eine Datumsspalte einfügen. Wie macht man dies bzw ist. das überhaupt möglich?

Später werden dann die CSV Dateien zusammen kopiert (was auch schon klappt) und via Pivot ausgwertet.

Für Tipps wäre ich dankbar.

Gruss
Mitglied: bastla
01.04.2010 um 12:46 Uhr
Hallo BBUser!

Etwa so:
01.
@echo off & setlocal
02.
set "Log=D:\Dein Log.csv"
03.

04.
set "LTemp=%temp%\LogTemp.txt"
05.
move "%Log%" "%LTemp%"
06.
for /f "delims=" %%i in (%LTemp%) do >>"%Log%" echo %date%;%%i
Grüße
bastla
Bitte warten ..
Mitglied: BBUser
01.04.2010 um 13:17 Uhr
Hallo bastla,

Danke für deine Hilfe.

Der Code funktioniert soweit schon recht gut, folgende Fehler treten noch auf.

1. ) Die Datumsspalte hat noch keine Überschrift wie z.b. date
2. ) Der zweiten Spalte in der CSV werden Sonderzeichen hinzugefügt, was den Import in Excel schwierig macht. Aus Server wird Server

Bekommen wir das gelöst?

Grüße
Bitte warten ..
Mitglied: bastla
01.04.2010 um 13:33 Uhr
Hallo BBUser!

Ungetestet:
01.
@echo off & setlocal
02.
set "Log=D:\Dein Log.csv"
03.

04.
set "LTemp=%temp%\LogTemp.txt"
05.
type "%Log%">"%LTemp%"
06.
del "%Log%"
07.
set "HeaderDone="
08.
for /f "delims=" %%i in (%LTemp%) do (
09.
    if defined HeaderDone (
10.
        echo %date%;%%i
11.
    ) else (
12.
        echo Datum;%%i
13.
        set "HeaderDone=True"
14.
    ) 
15.
)>>"%Log%"
[Edit] Ausgabe nach "%Log%" in die richtige Zeile gesetzt [/Edit]

Grüße
bastla
Bitte warten ..
Mitglied: BBUser
01.04.2010 um 13:54 Uhr
Hallo Bastla,

die Datumsspalte gibt es nun in der ersten Zeile.
Leider bleibt der restliche Inhalt verschwunden. Habe schon versucht dies zu lösen, aber ich finde den Fehler nicht - die for Schleife erscheint mir logisch.

/edit Fehler gefunden. Das schreiben in die Logdatei fehlte.
01.
set "Log=C:.....csv"
02.

03.
set "LTemp=C:.....txt"
04.

05.
type "%Log%">"%LTemp%"
06.
del "%Log%"
07.
set "HeaderDone="
08.
for /f "delims=" %%i in (%LTemp%) do (
09.
    if defined HeaderDone (
10.
        echo %date%,%%i >>"%Log%"    
11.
 ) else (
12.
        echo Datum,%%i
13.
        set "HeaderDone=True"
14.
    ) >>"%Log%" 
15.
)
Bekommt man das Sonderzeichen in der zweiten Spalte der ersten Zeile noch weg? Schaut in Excel so aus: Server


Grüße
Bitte warten ..
Mitglied: bastla
01.04.2010 um 14:12 Uhr
Hallo BBUser!

In meinem Ansatz oben war die Ausgabe in die Log-Datei eine Zeile zu hoch platziert (ist jetzt korrigiert).
Bekommt man das Sonderzeichen in der zweiten Spalte der ersten Zeile noch weg?
Wenn "man" wüsste, wo es herkommt (aus dem Batch nämlich eigentlich nicht), hätte "man" ev eine Chance ...

Grüße
bastla

P.S: In "Code"-Formatierung kannst Du zwar nicht fett schreiben, aber ansonsten ist sie für Batches besser geeignet.
Bitte warten ..
Mitglied: BBUser
01.04.2010 um 15:06 Uhr
Hallo Bastla,

danke. Hab das mal gemacht, mit dem Code. Schaut einfach besser aus ;)

Meine Batch schaut derzeit so aus.

01.

02.
for /f "tokens=1-5 delims=/.-:;, " %%a in ("%date%,%time%") do set folderdate=%%c%%b%%a
03.

04.
set logsource="E:\...\%folderdate%"
05.
set targetdir="C:\...\exports"
06.
set exe="C:\...\...stats.exe"
07.

08.
%exe% -p e -u all -l %logsource% -output all -ol %targetdir%
09.

10.

11.
ren "C:\...\HistoricalStats*.csv" "dailyuserstats_%folderdate%.csv"
12.

13.

14.
set "Log=C:\...\dailyuserstats_%folderdate%.csv"
15.

16.
set "LTemp=C:\...\exports\LogTemp.txt"
17.

18.
type "%Log%">"%LTemp%"
19.
del "%Log%"
20.
set "HeaderDone="
21.
for /f "delims=" %%i in (%LTemp%) do (
22.
    if defined HeaderDone (
23.
        echo %folderdate%,%%i >>"%Log%" 
24.
    ) else (
25.
        echo Datum,%%i
26.
        set "HeaderDone=True"
27.
    ) >>"%Log%" 
28.
)
29.

30.
move %Log% "C:\...\exports\dailystats\"
31.

32.
del %LTemp%
33.
Noch nicht sonderlich hübsch.. aber funktioniert erstmal.
Könnte hier irgendwo der Fehler mit dem Sonderzeichen liegen?


Bin dann noch auf ein weiteres Problem gestoßen.

Die erstellten CSV Dateien kopiere ich dann z.b. täglich in eine andere CSV. Dort schaut es soweit ganz gut aus, leider werden die ersten Zeilen der CSV Dateien mitgenommen, d.h. alle ~30 Zeilen taucht dann wieder Datum, Server,.... auf. Kann man sowas auf einfache Weise verhindern?

Der "Zusammen-Kopier-Job" schaut so aus (Stammt hier aus dem Forum):

01.
set "folder=C:\...\dailystats"
02.
set "report=C:\...\dailystats\Current_user_report.csv"
03.
set "line=C:\...\line1.txt"
04.

05.
copy "%line%" "%report%" >nul
06.
copy "%folder%\*.csv" "%report%.tmp" >nul
07.
findstr /v /b /c:"Text" "%report%.tmp">>"%report%"
08.
del "%report%.tmp"
09.
Grüße
Bitte warten ..
Mitglied: bastla
01.04.2010 um 16:18 Uhr
Hallo BBUser!

Hinsichtlich der Sonderzeichen habe ich keine Idee (Unicode als Ursache habe ich schon mit dem - ansonsten unnötigen - "type" eliminiert) ...
Was das "Zusammenkopieren" anlangt, setzt der Batch voraus, dass die Überschriftenzeile als "line1.txt" gespeichert ist - dann sollte aber eigentlich auch
01.
set "folder=C:\...\dailystats" 
02.
set "report=C:\...\dailystats\Current_user_report.csv" 
03.
set "line=C:\...\line1.txt" 
04.

05.
type "%line%" "%report%"
06.
type "%folder%\*.csv"|findstr /v /b /c:"%line%">>"%report%"
genügen ...

Grüße
bastla
Bitte warten ..
Ähnliche Inhalte
Windows XP

Zeilen einer zusammengeführten CSV Datei über Batch ändern

Frage von NelspruitWindows XP12 Kommentare

Hallo zusammen, ich habe über batch ca. 1000 CSV Datein (Messdaten) zusammengeführt. Das Ganze schaut nun in der neuen ...

Batch & Shell

Per Batch eine Spalte in eine CSV Datei einfügen

gelöst Frage von mayli01Batch & Shell13 Kommentare

Hallo Forum :) Folgende Ausgangssituation. Ich habe eine CSV Artikelliste mit insgesamt 9 Spalten, einer Kopfzeile und etwa 50 ...

Batch & Shell

CSV kleinerer Wert (Batch)

Frage von jochengBatch & Shell3 Kommentare

Ich habe eine CSV Datei mit folgendem Inhalt: 29664;24,95 29664;12,95 29645;9,95 29645;9,95 29655;12,95 29655;24,95 29664;24,95 29655,12,95 29655,24,95 29664;12,95 29664;24,95 ...

Batch & Shell

Batch - .csv to .txt

gelöst Frage von freshman2017Batch & Shell11 Kommentare

Hallo Ihr, ich habe da nochmal eine leichte kurze Frage, vielleicht hat da jemand ein Code für mich. Folgende ...

Neue Wissensbeiträge
Windows 7
Updategängelung auf Windows 10, die zweite
Information von Penny.Cilin vor 1 TagWindows 7

Hallo, da Windows 7 im kommenden Jahr nicht mehr supportet wird, werden Nutzer von Window 7 home premium wieder ...

Internet
EU-Urheberrechtsreform: Zusammenfassung
Information von Frank vor 4 TagenInternet1 Kommentar

Auf golem.de gibt es eine Analyse von Friedhelm Greis, der das Thema EU-Urheberrechtsreform gut und strukturiert zusammenfasst. Zwar haben ...

Microsoft Office

Office365 Schwachstellen bei Sicherheit und Datenschutz

Information von Penny.Cilin vor 5 TagenMicrosoft Office7 Kommentare

Auf Heise+ gibt es einen Artikel bzgl. Office365 Schwachstellen. Das ist noch ein Grund mehr seine Daten nicht in ...

Sicherheit
Schwachstellen in VPN Clients
Tipp von transocean vor 7 TagenSicherheit2 Kommentare

Moin, es gibt Sicherheitslücken bei VPN Clients namhafter Hersteller, wie man hier lesen kann. Gruß Uwe

Heiß diskutierte Inhalte
Windows Installation
Windows10 Home Neuinstallation - Raketentechnik
Frage von spacyfreakWindows Installation12 Kommentare

"Kannst du den Rechner von der Tante von WindowsXP auf Windows10 Home upgraden" haben sie gefragt? "Sicher, was kann ...

Virtualisierung
Unix System virtualisieren
Frage von BananenmeisterVirtualisierung10 Kommentare

Hallo Zusammen, Ich möchte gerne eine Virtualisierungs-Software auf meinem kleinen ML Server installieren um einige Unix Systeme zu virtualisieren. ...

Windows 10
Windows 10 verwendet FritzBox per IPv6 als DNS-Server an Stelle des per DHCP vergebenen DNS-Servers
Frage von Datax87Windows 1010 Kommentare

Hallo, ich habe ein kleines Problem mit der Namensauflösung (DNS) unter Windows 10. Mir ist heute aufgefallen, dass ich ...

Netzwerkmanagement
Konfiguration von IPv6 in einer Domäne mit DHCP
Frage von gnoovyNetzwerkmanagement10 Kommentare

Hi Zusammen, ich bin gerade etwas am verzweifeln. Ich habe eine Testumgebung aufgebaut, um mich in das Thema IPv6 ...