ITPub博客

首页 > 应用开发 > Python > python 调用 shell ,获取返回值和返回信息

python 调用 shell ,获取返回值和返回信息

原创 Python 作者:ittangzeng 时间:2019-01-15 22:25:27 0 删除 编辑

网络上有各种方案解决python调用shell的解决方案,但是没有一个完美的,以下是本人整理的一个方案,比较完美地解决了同时解决获取返回值和返回信息。


def run_linux_cmd_quiet(i_cmd, i_nohup='0'):

    l_func_name=__name__+ '.' + sys._getframe().f_code.co_name

    

    l_curTime=time.strftime('%Y%m%d_%H%M%S',time.localtime())

    l_result=l_curTime+str(os.getpid())+'.log'

    if i_nohup == '1':

        l_cmd="nohup {cmd} > {result} 2>&1 &".format(cmd=i_cmd, result=l_result)

    else:

        l_cmd="{cmd} > {result} 2>&1".format(cmd=i_cmd, result=l_result)

    val = os.system(l_cmd) 

    msg=file2List(l_result)

    if 0 != val:

        logger.print_error(l_func_name,common.concatString(l_cmd, 'failed.\n   retCode:',val))

    else:

        os.system('rm -f ' + l_result)

        if cfg.TRACE_FLAG == 'y':

            logger.print_info(l_func_name, common.concatString(l_cmd, 'ok.\n   retCode:',val))

    

    return (val,msg)


来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/29497382/viewspace-2558583/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论
欢迎一起交流技术:一个人可以走的很快,但是一群人却可以走的更远。 常见关系型数据库(Oracle+MySQL+PG+GP)+高可用+分布式锁 即时沟通工具:19578602(注明交流内容)

注册时间:2014-03-29

  • 博文量
    32
  • 访问量
    62609