首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用pdsh通过linux解析内联python命令

使用pdsh通过linux解析内联python命令
EN

Stack Overflow用户
提问于 2014-08-29 15:33:31
回答 1查看 426关注 0票数 0

因此,我尝试从一个python脚本发出这个命令,该脚本收集集群中预定数量的节点的cpu信息。在这里,我使用扇出为2,仅在节点b127到b129上运行它用于测试目的。

代码语言:javascript
复制
    pdsh -f2 -w b[127-129] 'python -c "import multiprocessing
    num_cpu = multiprocessing.cpu_count()
    stat_fd = open('/proc/stat')
    stat_fd.close()"'

我打印了命令,这是它在终端上显示的内容。因此,告诉我引号和命令的格式是正确的。我通过执行以下代码获得这个字符串:

代码语言:javascript
复制
    python_command = "'python -c "\
                 + "\"import multiprocessing\n"\
                 + "num_cpu = multiprocessing.cpu_count()\n"\
                 + "stat_fd = open(\'/proc/stat\')\n"\
                 + "stat_fd.close()\"'"

    command = "pdsh -f2 -w b[127-129] " + python_command
    print command

不幸的是,open(\'/proc/stat\')这行似乎是问题所在,因为这是由于嵌套单引号而导致解析器失败的唯一行。我已经尝试了许多引用和转义的组合,以使它工作无用。我在文件的打开和关闭之间省略了一些代码,以最小化发布的代码。

我到处搜索并找到了这个link,但发现它的示例太简单了,因为我可以复制这些命令。是的,我知道我可以使用bash命令来完成我想要做的事情,我可能最终会这样做,但这个命令会让我头疼。我也有使用top和ps收集数据的脚本,所以我不需要使用它们的解释。我非常感谢提前给予的帮助。

EN

回答 1

Stack Overflow用户

发布于 2014-08-29 15:44:40

试试这个:

代码语言:javascript
复制
python_command = """pdsh -f2 -w b[127-129] 'python -c "import multiprocessing
num_cpu = multiprocessing.cpu_count()
stat_fd = open(\\"/proc/stat\\")
stat_fd.close()"'"""

在Python语言中,可以对包含换行符和单/双引号的字符串使用三引号("""..."""'''...''')。

最后一层引号(在open()行上)需要转义,以便它们不会与外引号冲突。您还需要对反斜杠进行转义,以便在解释字符串:\\"时不会立即被Python使用。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/25563614

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档