Log de console usando saída de comando de script ilegível

3

Eu queria registrar a saída do meu programa (o programa python inicializa um dispositivo embarcado conectado a uma porta serial) a um arquivo de texto console_log.txt usando um script shell, para o qual escrevi o seguinte script:

#!/bin/bash
current_time=$(date "+%Y.%m.%d-%H.%M.%S")
gnome-terminal -x bash -c "cd ~/Scripts;pwd;script -c \"python test.py $1\" ~/Output/console_log_$current_time.txt;exec $SHELL"

O texto acima escreve caracteres ilegíveis (não ASCII) no arquivo ao longo das linhas de:

捓楲瑰猠慴瑲摥漠桔牵摳祡〠‶灁楲〲㜱〠㨳㔲㈺‸䵐䤠呓ഊ上⹯漠⁦慰慲敭整獲瀠潲楶敤⁤祢琠敨甠敳⁲›ㄠ਍਍敔瑳漠瑰潩湥整敲⁤›〠਍獕湩⁧敤慦汵⁴潣普杩牵瑡潩楦敬⸮⸮਍਍⨪⨪⨪⨪⨪桔⁥潣普杩牵瑡潩楦敬琠慨❴⁳潧湩⁧潴戠⁥獵摥椠⁳›㰠潮敮ാ猊慴瑲湩⁧慭湩猠牣灩൴⼊潨敭愯瑵浯瑡潩㑮愯瑵浯瑡潩⽮噄㥆弹畁潴慭楴湯਍栯浯⽥畡潴慭楴湯⼴畡潴慭楴湯䐯䙖㤹䅟瑵浯瑡潩⽮湉異⽴਍❛灳捥牴浵睟形档物⹰慷❶‬洧污彥欸眮癡Ⱗ✠灳捥牴浵湟形楤捳㍟〶⸰慷❶‬猧数瑣畲彭扮损楨灲眮癡Ⱗ✠灳捥牴浵睟形楤捳㕟〸⸰慷❶‬琧獥⹴慷❶‬洧污彥㘱⹫慷❶‬昧汭扟灵慟瑴潟杲眮癡崧㠠਍栯浯⽥畡潴慭楴湯⼴畡潴慭楴湯䐯䙖㤹䅟瑵浯瑡潩⽮湉異⽴潣普杩琮瑸਍††††††††††唠䕓⁒†††倠䑉䄠䍃卅⁓佃䵍乁ൄ⼊敤⽶瑴啹䉓㨸††††畡潴慭楴湯‴㈠㘲㔷䘠⸮⸮氠杯湩楟楮൴⼊敤⽶瑴啹䉓㨹††††畡潴慭楴湯‴㈠㘲㔶䘠⸮⸮氠杯湩楟楮൴匊牥慩潐瑲⁳楬瑳㨠†❛✹‬㠧崧਍敓楲污瀠牯獴㨠†❛搯癥琯祴单㥂Ⱗ✠搯癥琯祴单㡂崧਍桃灩敳⁴‱›ㄠ㄰਍桃灩敳⁴′›ㄠ㄰਍潂牡⁤‱敓楲污倠牯⁴›⼠敤⽶瑴啹䉓ഹ䈊慯摲㈠匠牥慩潐瑲㨠†搯癥琯祴单㡂਍潂牡ㅤ䤠⁐›ㄠ㈷㈮⸸⸴㈳਍潂牡㉤䤠⁐›ㄠ㈷㈮⸸⸴㘳਍潂牡㍤䤠⁐›ㄠ㈷㈮⸸⸴㔲਍潂牡㑤䤠⁐›ㄠ㈷㈮⸸⸴㜲਍潂牡㕤䤠⁐›ㄠ㈷㈮⸸⸴㠵਍汯⁤敲畳瑬搠汥猠捵散獳⹳⸮‮慰獳਍潔‽❛牳敥慫瑮⹨䁳獤杰挮浯崧਍灓楬⁴潶灩‽ര⨊⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪਍⨪⨪⨪⨪⨪⨪⨪潓湵⁤慃摲䌠湯捥楴湯⩳⨪⨪⨪⨪⨪⨪പ⨊⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪਍佂剁ㅄⴠ㸭戠弱畯彴潰瑲漽瑵档ⰱ戠弱湩灟牯㵴湩档റ䈊䅏䑒′ⴭ‾㉢潟瑵灟牯㵴畯捴㉨‬㉢楟彮潰瑲椽据㉨਍⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪പഊ嬊⼧敤⽶瑴啹䉓✹‬⼧敤⽶瑴啹䉓✸‬⼧敤⽶瑴啹䉓✳‬⼧敤⽶瑴啹䉓✲‬⼧敤⽶瑴啹䉓✱‬⼧敤⽶瑴啹䉓✰‬⼧敤⽶瑴卹✰൝嬊⼧敤⽶瑴啹䉓✹‬⼧敤⽶瑴啹䉓✸‬⼧敤⽶瑴啹䉓✳‬⼧敤⽶瑴啹䉓✲‬⼧敤⽶瑴啹䉓✱‬⼧敤⽶瑴啹䉓✰‬⼧敤⽶瑴卹✰൝䈊慯摲†椠⁰†‽㜱⸲㠲㐮㈮㤰਍慇整慷⁹灩†㴠ㄠ㈷㈮⸸⸴㔲ഴ䌊浯瀠牯

Ou gedit exibe mensagens como:

Could not open the file “/home/user4/con…g_2017.04.06-16.05.48.txt”.
Unexpected error: Invalid byte sequence in conversion input

quando tento abrir o arquivo.

Quando eu executo algo mais simples como:

script -c ifconfig ~/user4/Scripts/test.txt

funciona muito bem, ou seja, eu recebo a saída esperada no arquivo de log. Como evitar esses caracteres ilegíveis?

    
por skrowten_hermit 06.04.2017 / 12:13

1 resposta

2

No caso, se você estiver executando o script python no ambiente Linux, siga os passos abaixo antes de executar o script:

$ script console_log.txt
$ run your python script
$ exit  (After the script completes execution)

Registros inteiros do console serão capturados em "console_log.txt"

    
por 20.08.2018 / 09:02