Forum: PC-Programmierung Shell Cat bestimmter Zeitraum aus CSV


von Jens (Gast)


Lesenswert?

Hallo zusammen,

ich habe ein Problem, um per Shellscript einen bestimmten Zeitbereich 
einer CSV-Datei in eine andere zu schreiben:

Aufbau der CSV-Datei:
2018-01-09 11:45:27, 316-2016 
:45:0,7.09,38.36,28.80,25.40,25.97,18.84,18.71,11.68,6.89,42.07
2018-01-09 11:45:39, 316-2016 
20:45:0,7.09,38.66,29.06,25.40,25.93,19.02,18.79,11.68,6.89,42.04
2018-01-09 11:45:51, 316-2016 
20:45:0,7.09,38.94,29.29,25.35,25.93,19.08,18.83,11.68,6.89,42.10
2018-01-09 11:46:04, 316-2016 
20:45:0,7.10,39.20,29.55,25.31,25.93,19.27,18.83,11.68,6.89,42.10

Diese Zeitangaben sind über mehrere Monate und Tage hinweg, wobei die 
relevante Information zu Beginn steht.



Gibt es eine Möglichkeit einen bestimmten Zeitbereich per CAT Befehl in 
eine andere zu schreiben. Z.b 2017-21-12 00:00 bis 2018-01-07 24:00

Vielen Dank schonmal

von Stefan P. (form)


Lesenswert?

So richtig akkurat geht das über ein paar Umwege - entweder installierst 
du "dategrep" oder wandelst die Zeitstempel erst ins Unixtime Format um, 
und filterst die Zeilen dann je nachdem dem Zahlenwert im gewünschten 
Bereich liegt.

Eine etwas schnellere Möglichkeit ist die stumpfe Ausgabe aller Zeilen 
"zwischen" zwei bekannten Zeitstempeln die auch existieren müssen:
1
sed -n '/2017-21-12 00:00:00/,/2018-01-07 23:59:59/p' input.csv

von Der kein Bock mehr A. (Gast)


Lesenswert?

> Eine etwas schnellere Möglichkeit ist die stumpfe Ausgabe aller Zeilen
> "zwischen" zwei bekannten Zeitstempeln die auch existieren müssen:
>
1
sed -n '/2017-21-12 00:00:00/,/2018-01-07 23:59:59/p' 
2
> input.csv

Ja, so ähnlich musste ich das auch mal machen, man definiert eine Start 
und eine Stop-Marke und holt sich das dazwischen raus ...
Musste ich mal für TSM-Logs aus der dsmsched.log machen oder für ne 
automatische Generierung von Doxygen-Sourcecode-Dokus ...

Wenn ich nohc Beispiele finden sollte, poste ich die , aber ist schon 
ewig her
Gruß

von Markus M. (adrock)


Lesenswert?

...oder Du nimmst AWK:

$ awk -v start=2018-01-10 -v end=2018-01-12 '$1 >= start && $1 <= end { 
print "match: " $0 }' << EOF
> 2018-01-09
> 2018-01-10
> 2018-01-11
> 2018-01-12
> 2018-01-13
> 2000-05-06
> 2999-01-01
> EOF
match: 2018-01-10
match: 2018-01-11
match: 2018-01-12

(ja ich weiss, ist ein Dinosaurier, aber ein praktischer :-)

: Bearbeitet durch User
Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.