我想使用shell脚本将我的程序(python程序启动连接到串口的无头嵌入式设备)输出到文本文件console_log.txt,为此,我编写了以下脚本:
#!/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"
以上内容将不可读(非ASCII)字符写入文件中:
捓楲瑰猠慴瑲摥漠桔牵摳祡〠‶灁楲〲㜱〠㨳㔲㈺‸䵐䤠呓ഊ上漠慰慲敭整獲瀠潲楶敤祢琠敨甠敳›ㄠ敔瑳漠瑰潩湥整敲›〠獕湩敤慦汵⁴潣普杩牵瑡潩楦敬⸮⸮⨪⨪⨪⨪⨪桔潣普杩牵瑡潩楦敬琠慨❴潧湩潴戠獵摥椠›㰠潮敮ാ猊慴瑲湩慭湩猠牣灩൴⼊潨敭愯瑵浯瑡潩㑮愯瑵浯瑡潩⽮噄㥆弹畁潴慭楴湯栯浯⽥畡潴慭楴湯⼴畡潴慭楴湯䐯䙖㤹䅟瑵浯瑡潩⽮湉異⽴❛灳捥牴浵睟形档物慷❶洧污彥欸眮癡Ⱗ✠灳捥牴浵湟形楤捳㍟〶⸰慷❶猧数瑣畲彭扮损楨灲眮癡Ⱗ✠灳捥牴浵睟形楤捳㕟〸⸰慷❶琧獥慷❶洧污彥㘱慷❶昧汭扟灵慟瑴潟杲眮癡崧㠠栯浯⽥畡潴慭楴湯⼴畡潴慭楴湯䐯䙖㤹䅟瑵浯瑡潩⽮湉異⽴潣普杩琮瑸††††††††††唠䕓⁒†††倠䑉䄠䍃卅⁓佃䵍乁ൄ⼊敤⽶瑴啹䉓㨸††††畡潴慭楴湯‴㈠㘲㔷䘠⸮⸮氠杯湩楟楮൴⼊敤⽶瑴啹䉓㨹††††畡潴慭楴湯‴㈠㘲㔶䘠⸮⸮氠杯湩楟楮൴匊牥慩潐瑲楬瑳㨠†❛✹㠧崧敓楲污瀠牯獴㨠†❛搯癥琯祴单㥂Ⱗ✠搯癥琯祴单㡂崧桃灩敳⁴‱›ㄠ桃灩敳⁴′›ㄠ潂牡‱敓楲污倠牯⁴›⼠敤⽶瑴啹䉓ഹ䈊慯摲㈠匠牥慩潐瑲㨠†搯癥琯祴单㡂潂牡ㅤ䤠⁐›ㄠ㈷㈮⸸⸴㈳潂牡㉤䤠⁐›ㄠ㈷㈮⸸⸴㘳潂牡㍤䤠⁐›ㄠ㈷㈮⸸⸴㔲潂牡㑤䤠⁐›ㄠ㈷㈮⸸⸴㜲潂牡㕤䤠⁐›ㄠ㈷㈮⸸⸴㠵汯敲畳瑬搠汥猠捵散獳⸮慰獳潔‽❛牳敥慫瑮䁳獤杰挮浯崧灓楬⁴潶灩‽ര⨊⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪潓湵慃摲䌠湯捥楴湯⩳⨪⨪⨪⨪⨪⨪പ⨊⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪佂剁ㅄⴠ㸭戠弱畯彴潰瑲漽瑵档ⰱ戠弱湩灟牯㵴湩档റ䈊䅏䑒′ⴭ‾㉢潟瑵灟牯㵴畯捴㉨㉢楟彮潰瑲椽据㉨⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪⨪പഊ嬊⼧敤⽶瑴啹䉓✹⼧敤⽶瑴啹䉓✸⼧敤⽶瑴啹䉓✳⼧敤⽶瑴啹䉓✲⼧敤⽶瑴啹䉓✱⼧敤⽶瑴啹䉓✰⼧敤⽶瑴卹✰൝嬊⼧敤⽶瑴啹䉓✹⼧敤⽶瑴啹䉓✸⼧敤⽶瑴啹䉓✳⼧敤⽶瑴啹䉓✲⼧敤⽶瑴啹䉓✱⼧敤⽶瑴啹䉓✰⼧敤⽶瑴卹✰൝䈊慯摲†椠⁰†‽㜱⸲㠲㐮㈮㤰慇整慷⁹灩†㴠ㄠ㈷㈮⸸⸴㔲ഴ䌊浯瀠牯
或者gedit会显示以下消息:
Could not open the file “/home/user4/con…g_2017.04.06-16.05.48.txt”.
Unexpected error: Invalid byte sequence in conversion input
当我尝试打开文件.
当我运行一些更简单的事情时:
script -c ifconfig ~/user4/Scripts/test.txt
它运行得很好,即我在日志文件中得到预期的输出.如何避免这种难以理解的角色?
解决方法:
如果您在Linux环境中运行python脚本,请在运行脚本之前按照以下步骤操作:
$script console_log.txt
$run your python script
$exit (After the script completes execution)
整个控制台日志将在“console_log.txt”中捕获
原文地址:https://codeday.me/bug/20190814/1658267.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。