子流程变量[重复]

2023-11-23

  1 import subprocess
  2 raw = raw_input("Filename:").lower()
  3 ip = raw_input("Host:").lower()
  4 cmd = subprocess.call("tcpdump -c5 -vvv -w" + " raw " + " ip ",shell=True)

这就是我的脚本。除了使用原始输入的一个关键目标之外,一切都正常。 它允许我输入任何我想要的东西,但是当它保存文件或使用 ip/主机时,doe 实际上并没有做任何事情。 当然它给了我数据包,但来自本地主机而不是我输入的主机。

我怎么知道这不起作用是因为我的第一个原始输入是文件名,所以我进行了测试,当我查看我的脚本所在的文件夹时,它会生成一个名为“raw”的文件,意思是,它实际上并没有采用我的仅使用我的“X”内的内容输入...

所以我找了几次机会来讨论这个问题:

  1 import subprocess
  2 raw = raw_input("Filename:").lower()
  3 ip = raw_input("Host:").lower()
  4 cmd = subprocess.call("tcpdump -c5 -vvv -w" + raw + "host" + ip,shell=True)

这很棒,因为它实际上需要 -w 但它现在将其保存为 rawhostip 而不是“raw”输入。 作为参考,命令在终端中如下所示:

tcpdump -c5 -vvv -w savename host wiki2

唯一的两个变量是 savename 和 wiki2 ,其余的变量是命令工作所必需的。

使用此脚本我收到此错误:

import subprocess
raw = raw_input("Filename:").lower()
ip = raw_input("Host:").lower()
cmd = subprocess.call("tcpdump -c5 -vvv -w" + raw, "host" + ip,shell=True)

Error:

Traceback (most recent call last):
  File "te.py", line 4, in <module>
    cmd = subprocess.call("tcpdump -c5 -vvv -w" + raw, "host" + ip,shell=True)
  File "/usr/lib/python2.6/subprocess.py", line 480, in call
    return Popen(*popenargs, **kwargs).wait()
  File "/usr/lib/python2.6/subprocess.py", line 583, in __init__
    raise TypeError("bufsize must be an integer")
TypeError: bufsize must be an integer

我迷路了。任何帮助都会很棒,是的,我知道在现场查看子流程的文档:X,我需要一个人来教我,我不明白我在读什么。

我的问题是如何处理这些变量。


不要使用shell=True。那应该是False.

您在输入时犯了一些微妙的错误。具体来说,如果您有两个字符串:

>>> s1 = 'Hello'
>>> s2 = 'Hi'
>>> s1 + s2
'HelloHi'

注意,中间没有空格Hello and Hi。所以不要这样做。 (你的4号线)

你应该这样做(好方法):

>>> raw = raw_input('Filename: ')
Filename: test
>>> ip = raw_input('Host: ')
Host: 192.168.1.1 
>>> command = 'tcpdump -c5 -vvv -w {0} {1}'.format(raw, ip)   # the command goes here
>>> subprocess.call(command.split(), shell=False)   # call subprocess and pass the command as a list using split

现在应该可以了。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

子流程变量[重复] 的相关文章

随机推荐