python命令提示符后的小白块是什么_Python:响应命令行提示

我试图通过命令行使用Python与另一个程序进行交互.我遇到的主要问题是具有多个后续提示的特定呼叫.最初,命令行调用询问项目的名称,然后继续询问我是否要查看项目的任何子文件夹.我需要按顺序回答每一个的y / n,遗憾的是,每个y或n的答案都不是y或n.另外,如果不阅读个别提示,我无法知道问题的答案,因此我无法一次性发送“y”或“n”块.

这是命令行调用:

si viewproject

输入命令后,命令行会提示:

输入项目名称:

一个示例响应是:

输入项目名称:c:/test.pj

进入项目后,它会提示以下内容:

你想进入子项目test_subprj.pj吗? [ynYN](n)的

在这一点上,我需要用y或n来响应,这取决于我是否需要该子项目.同样,对这个问题的回答取决于子项目.我需要能够在此提示中读取子项目,以便用’y’或’n’来响应它

目前我需要分别手动输入项目以及y和n中的每一个.我的目标是使用Python自动执行此过程.

有没有办法自动响应这些命令行提示?

目前的进展

子流程策略

project_path = "c:/test.pj"

with Popen(["si", "viewproject", "--project=" + project_path],

stdin=PIPE, stdout=PIPE, universal_newlines=True) as p:

for line in p.stdout:

if line.startswith("Do you want"):

answer = 'n'

else:

continue # skip it

print(answer, file=p.stdin) # provide answer

p.stdin.flush()

使用Popen语句后,此方法挂起.它永远不会出错,但它永远不会进入或退出for语句而永远不会完成.目前我默认所有“n”的答案,但稍后将用逻辑替换.

Winpexpect战略

import re

import sys

from functools import partial

import winpexpect

project_path = "c:/test.pj"

p = winpexpect.winspawn('si viewproject --project=' + project_path)

p.logfile = sys.stdout

patterns = [re.compile('ynYN'), winpexpect.EOF]

for found in iter(partial(p.expect, patterns), 1): # until EOF

if found == 0:

answer = 'n'

p.sendline(answer)

返回以下错误消息:

Traceback (most recent call last):

File "C:\Python33\lib\site-packages\winpexpect-1.5-py3.3.egg\winpexpect.py", line 541, in read_nonblocking

handle, status, data = self.child_output.get(timeout=timeout)

File "C:\Python33\lib\queue.py", line 175, in get

raise Empty

queue.Empty

During handling of the above exception, another exception occurred:

Traceback (most recent call last):

File "C:\Python33\lib\site-packages\winpexpect-1.5-py3.3.egg\pexpect.py", line 1378, in expect_loop

c = self.read_nonblocking (self.maxread, timeout)

File "C:\Python33\lib\site-packages\winpexpect-1.5-py3.3.egg\winpexpect.py", line 543, in read_nonblocking

raise TIMEOUT('Timeout exceeded in read_nonblocking().')

pexpect.TIMEOUT: Timeout exceeded in read_nonblocking().

During handling of the above exception, another exception occurred:

Traceback (most recent call last):

File "K:\eclipse_3.6.0\plugins\org.python.pydev_2.6.0.2012062818\pysrc\pydev_runfiles.py", line 432, in __get_module_from_str

mod = __import__(modname)

File "C:\workspace\Test_prj\Test_prj.py", line 19, in

for found in iter(partial(p.expect, patterns), 1): # until EOF

File "C:\Python33\lib\site-packages\winpexpect-1.5-py3.3.egg\pexpect.py", line 1311, in expect

return self.expect_list(compiled_pattern_list, timeout, searchwindowsize)

File "C:\Python33\lib\site-packages\winpexpect-1.5-py3.3.egg\pexpect.py", line 1325, in expect_list

return self.expect_loop(searcher_re(pattern_list), timeout, searchwindowsize)

File "C:\Python33\lib\site-packages\winpexpect-1.5-py3.3.egg\pexpect.py", line 1409, in expect_loop

raise TIMEOUT (str(e) + '\n' + str(self))

pexpect.TIMEOUT: Timeout exceeded in read_nonblocking().

version: 2.3 ($Revision: 399 $)

command: si

args: ['si', 'viewproject', '--project=c:/test.pj']

searcher: searcher_re:

0: re.compile("ynYN")

1: EOF

buffer (last 100 chars):

before (last 100 chars):

after:

match: None

match_index: None

exitstatus: None

flag_eof: False

pid: 6448

child_fd: 4

closed: False

timeout: 30

delimiter:

logfile: <_io.textiowrapper name="<stdout>" mode="w" encoding="Cp1252">

logfile_read: None

logfile_send: None

maxread: 2000

ignorecase: False

searchwindowsize: None

delaybeforesend: 0.05

delayafterclose: 0.1

delayafterterminate: 0.1

ERROR: Module: Test_prj could not be imported (file: C:\workspace\Test_prj\Test_prj.py).

安装Winpexpect

懒人的方式

第一世界的问题

Python对我来说是一种新语言,我之前从未为Python安装过包.此外,Python 3.x与其他版本的Python略有不同,使得安装模块更具冒险性.

因此,为了帮助其他人获得一些甜蜜的模块动作(并帮助那些知识渊博的人看看我做错了什么),这是一个很快成功的故事(希望)记录我是如何得到并安装我的第一个模块的.

设定

Python允许第三方组开发和分发扩展编程语言功能的模块.当然,有一种标准方法可以帮助第三方开发人员尽可能轻松地为最终用户提供模块.

对于Python 3.x,分发模块的标准称为Distutils.

通常,在命令行中导航到下载模块的文件夹并运行“setup.py install”就足够了.

有时候生活并不那么容易,您的安装可能仍然存在问题.事实上,你可能需要别的东西.例如,您可能会收到以下错误:

“ImportError”没有名为Setuptools的模块“”

事实证明,并非所有东西都使用distutils.有些软件包使用setuptools.不幸的是,Python 3.x没有setuptools.相反,Python 3.x使用distribute,它是setuptools的一个分支.

所以对于那些使用Python 3.x的人来说,这里是Distribute:Distribute

对于使用Python 2.x的用户,这里是Setuptools:Setuptools

在“分发安装说明”中,它说明如下:

“下载

distribute_setup.py< http://python-distribute.org/distribute_setup.py\u0026gt; _

并使用您选择的Python解释器执行它.“

它还说:“请注意,此文件也在源版本中提供.”

所以我下载了Distribute并将其保存到了计算机上.将它保存到计算机后,我从源版本运行distribute_setup.py并收到以下错误:

Downloading http://pypi.python.org/packages/source/d/distribute/distribute-0.6.36.tar.gz

Traceback (most recent call last):

File "C:\Python33\lib\urllib\request.py", line 1252, in do_open

h.request(req.get_method(), req.selector, req.data, headers) File "C:\Python33\lib\http\client.py", line 1049, in request

self._send_request(method, url, body, headers)

File "C:\Python33\lib\http\client.py", line 1087, in _send_request

self.endheaders(body)

File "C:\Python33\lib\http\client.py", line 1045, in endheaders

self._send_output(message_body)

File "C:\Python33\lib\http\client.py", line 890, in _send_output

self.send(msg)

File "C:\Python33\lib\http\client.py", line 828, in send

self.connect()

File "C:\Python33\lib\http\client.py", line 806, in connect

self.timeout, self.source_address)

File "C:\Python33\lib\socket.py", line 406, in create_connection

for res in getaddrinfo(host, port, 0, SOCK_STREAM):

socket.gaierror: [Errno 11001] getaddrinfo failed

During handling of the above exception, another exception occurred:

Traceback (most recent call last):

File "C:\workspace\PythonTest\distribute_setup.py", line 553, in

sys.exit(main())

File "C:\workspace\PythonTest\distribute_setup.py", line 549, in main

tarball = download_setuptools(download_base=options.download_base)

File "C:\workspace\PythonTest\distribute_setup.py", line 204, in download_setuptools

src = urlopen(url)

File "C:\Python33\lib\urllib\request.py", line 160, in urlopen

return opener.open(url, data, timeout)

File "C:\Python33\lib\urllib\request.py", line 473, in open

response = self._open(req, data)

File "C:\Python33\lib\urllib\request.py", line 491, in _open

'_open', req)

File "C:\Python33\lib\urllib\request.py", line 451, in _call_chain

result = func(*args)

File "C:\Python33\lib\urllib\request.py", line 1272, in http_open

return self.do_open(http.client.HTTPConnection, req)

File "C:\Python33\lib\urllib\request.py", line 1255, in do_open

raise URLError(err)

urllib.error.URLError:

那不好!老实说,我仍然不知道错误来自哪里或为什么会发生.

无论如何,我发现以下网站运行.exe来安装分发以及pip.

所以我安装了这些,然后使用以下站点设置我的电脑,以便更轻松地使用easy_install:Setting Up Easy Install Made Easy

一旦我开始工作,我就安装了鼻子:Nose

我得到鼻子的原因是因为Winpexpect website说:

“WinPexpect包括单元测试.要运行测试,需要鼻子.使用以下命令运行测试:

$python setup.py test“

那听起来不错:).现在我只是希望我知道在哪里进行测试.我知道如果你手动安装,你可以使用setup.py install命令,因此在线压缩目录中肯定会有一个setup.py.为了查看这是否正确,我下载并保存了winpexpect文件,提取了信息,通过命令行导航到它,然后运行setup.py test.

这是以下结果:

running test

running build_py

running egg_info

creating c:\documents and settings\slz1fh\desktop\winpexpect\geertj-winpexpect-76df3cfcb143\build\lib\winpexpect.egg-info

writing c:\documents and settings\slz1fh\desktop\winpexpect\geertj-winpexpect-76df3cfcb143\build\lib\winpexpect.egg-info\PKG-INFO

writing dependency_links to c:\documents and settings\slz1fh\desktop\winpexpect\geertj-winpexpect-76df3cfcb143\build\lib\winpexpect.egg-info\dependency_links.txt

writing top-level names to c:\documents and settings\slz1fh\desktop\winpexpect\geertj-winpexpect-76df3cfcb143\build\lib\winpexpect.egg-info\top_level.txt

writing requirements to c:\documents and settings\slz1fh\desktop\winpexpect\geertj-winpexpect-76df3cfcb143\build\lib\winpexpect.egg-info\requires.txt

writing manifest file 'c:\documents and settings\slz1fh\desktop\winpexpect\geertj-winpexpect-76df3cfcb143\build\lib\winpexpect.egg-info\SOURCES.txt'

reading manifest file 'c:\documents and settings\slz1fh\desktop\winpexpect\geertj-winpexpect-76df3cfcb143\build\lib\winpexpect.egg-info\SOURCES.txt'

writing manifest file 'c:\documents and settings\slz1fh\desktop\winpexpect\geertj-winpexpect-76df3cfcb143\build\lib\winpexpect.egg-info\SOURCES.txt'

running build_ext

Traceback (most recent call last):

File "C:\Documents and Settings\SLZ1FH\Desktop\winpexpect\geertj-winpexpect-76df3cfcb143\setup.py", line 35, in

use_2to3 = True

File "C:\Python33\lib\distutils\core.py", line 148, in setup

dist.run_commands()

File "C:\Python33\lib\distutils\dist.py", line 917, in run_commands

self.run_command(cmd)

File "C:\Python33\lib\distutils\dist.py", line 936, in run_command

cmd_obj.run()

File "C:\Python33\lib\site-packages\distribute-0.6.36-py3.3.egg\setuptools\command\test.py", line 138, in run

self.with_project_on_sys_path(self.run_tests)

File "C:\Python33\lib\site-packages\distribute-0.6.36-py3.3.egg\setuptools\command\test.py", line 118, in with_project_on_sys_path

func()

File "C:\Python33\lib\site-packages\distribute-0.6.36-py3.3.egg\setuptools\command\test.py", line 164, in run_tests

testLoader = cks

File "C:\Python33\lib\unittest\main.py", line 124, in __init__

self.parseArgs(argv)

File "C:\Python33\lib\unittest\main.py", line 168, in parseArgs

self.createTests()

File "C:\Python33\lib\unittest\main.py", line 175, in createTests

self.module)

File "C:\Python33\lib\unittest\loader.py", line 137, in loadTestsFromNames

suites = [self.loadTestsFromName(name, module) for name in names]

File "C:\Python33\lib\unittest\loader.py", line 137, in

suites = [self.loadTestsFromName(name, module) for name in names]

File "C:\Python33\lib\unittest\loader.py", line 96, in loadTestsFromName

module = __import__('.'.join(parts_copy))

File "C:\Python33\lib\site-packages\nose-1.3.0-py3.3.egg\nose\__init__.py", line 1, in

from nose.core import collector, main, run, run_exit, runmodule

File "C:\Python33\lib\site-packages\nose-1.3.0-py3.3.egg\nose\core.py", line 143

print "%s version %s" % (os.path.basename(sys.argv[0]), __version__)

^

SyntaxError: invalid syntax

好的,所以Python 3.3版的Nose包含Python 3.3的无效语法?

print“%s version%s”%(os.path.basename(sys.argv [0]),version)…

应该肯定有括号…这让我怀疑鼻子是否真的在这里工作,因为它明显看起来是为早期版本的Python.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值