Forum: PC-Programmierung Shell call up another system (cu) mit 2 pipes


von Peter (Gast)


Lesenswert?

Hallo zusammen,

ich bin neu in der Linux-Welt und versuche einen Datenlogger 
anzusprechen. Das funktioniert auch soweit ganz gut. Allerdings kommt es 
zu fehlerhaften Darstellungen, wenn ich die serielle Schnittstelle 
öffne, während der Datenlogger gerade sendet. Das versuche ich mit 
"grep" abzufangen, da der Datenlogger zu Beginn immer 316,############ 
sendet. Umleiten will ich die eingelesene Zeile mit einem Zeitstempel.

Mein Befehl dafür sieht folgendermaßen aus:
1
/usr/bin/cu -l /dev/ttyACM0 -s 9600 | grep ^316 | ts '%Y-%m-%d %H:%M:%S,'

Das funktioniert aber nicht. Wenn ich sowohl |grep ^316 weglasse 
funktioniert die Ausgabe, als auch | ts ....

Im Internet finde ich dazu keine weitere Hilfe. Dort steht überall, dass 
man mehrere Pipes aneinander hängen kann.

Wenn ich
1
echo 316 xyz | grep ^316 | ts '%Y-%m-%d %H:%M:%S,'
versuche, funktioniert alles wunderbar.

Weiss jemand, wieso der erste Befehl nicht funktioniert.

Vielen Dank schonmal

von foobar (Gast)


Lesenswert?

Eine Möglichkeit: grep buffered die Ausgabe und es dauert einfach nur 
sehr lange, bis die ersten Daten ausgegeben werden. Bei der 
echo-Variante geht's fix, da er sofort ein EOF bekommt. Probier mal die 
grep-Option "--line-buffered".

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.