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
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 |
> 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ß
...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
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.