云网牛站
所在位置:首页 > Linux编程 > Shell脚本因使用管道连接符而出现执行错误的解决

Shell脚本因使用管道连接符而出现执行错误的解决

2020-11-21 15:51:00作者:ylxdxx稿源:深度站

本文介绍Shell脚本执行错误解决一例。问题的奇怪之处为里面Python的语句没有正确执行,可以用Python执行一些程序,但会报一些奇怪的错误。

 

相关说明

最近使用了以前编写的一个脚本(Shell),但是执行的结果有问题里面:有些语句没有被正确执行,期间重新安装过所需Python模块、换过脚本解释器,甚至将语句单独复制出来逐行执行,里面的语句没有一句有问题,都可以单独正确执行,重新建立文件在终端中执行,没有问题,想过是字符或者编码,将能够正确执行的文件重新命名替换,执行依然依然出错。其中Shell的错误代码是120,解释是Is a named type file。

最后锁定了问题所在,原因是在执行这个命令的时候,使用管道连接符的问题,又想起了以前使用sed的管道出现的一些莫名其妙的问题。

 

复现示例

在https://github.com/migvel/color_trace地址里面有一个转换脚本color_trace_multi.py。

新建一个test.sh文件,加上一句话:

python3 color_trace_multi.py -i test2.png -o test2.svg -c 3

给予可执行权限,用如下命令执行就报错:

./test.sh |  echo "123"

参考:echo命令_Linux echo命令使用详解:输出指定的字符串或者变量

用如下命令执行就正确:

./test.sh

 

解释说明

类似的Shell代码,我没试出下列错误(没试 color_trace):

Is a named type file

倒是有其他错误:

$ python3 -c 'for i in range(6): print(i)' | echo 123

123

Exception ignored in: <_io.TextIOWrapper name='<stdout>' mode='w' encoding='utf-8'>

BrokenPipeError: [Errno 32] Broken pipe

查到说:echo关闭了管道读端,此时发送SIGPIPE信号python3,默认杀进程。但python3选择触发BrokenPipeError异常,然后就这样了。

Shell脚本因使用管道连接符而出现执行错误的解决

Shell脚本因使用管道连接符而出现执行错误的解决

说明:应该是Python对信号处理的问题,用在shell里用$?获取退出的值是120,查了一下含义,其为Is a named type file而使用| echo 123,是为了不管前面的程序咋样,都能获得一个正确的退出信号和退出相关字符,现在已用其它方式解决。

 

相关主题

第3章 管道符、重定向与环境变量

精选文章
热门文章