我正在用Python编写一个IRC bot。
我希望为Linux和Windows制作独立的二进制文件。主要是我希望当机器人启动时,控制台窗口应该隐藏,用户不应该看到窗口。
我能为此做些什么?
答案 0 :(得分:95)
只需使用.pyw
扩展名保存即可。这将阻止控制台窗口打开。
在Windows系统上,没有“可执行模式”的概念。 Python安装程序会自动将.py文件与python.exe相关联,这样双击Python文件就会将其作为脚本运行。 扩展名也可以是.pyw,在这种情况下,通常显示的控制台窗口会被禁止。
答案 1 :(得分:29)
在linux中,只需运行它,没问题。在Windows中,您希望使用pythonw可执行文件。
好的,如果我在评论中理解了这个问题,你就会问如何在命令行中启动机器人的命令窗口后来消失?
$ nohup mypythonprog&
C:/>启动pythonw mypythonprog
我认为是对的。无论如何,现在你可以关闭终端。
答案 2 :(得分:17)
使用nohup mypythonprog &
,您可以在不中断过程的情况下关闭终端窗口。如果您在云中运行并且不想保留挂起的shell进程,也可以运行exit
。
使用.pyw
扩展程序保存该程序,现在它将以pythonw.exe
打开。没有shell窗口。
例如,如果您有foo.py
,则需要将其重命名为foo.pyw
。
答案 3 :(得分:9)
如果您只想在安装了Python解释器的Windows计算机上运行Python脚本,请将保存的脚本的扩展名转换为' .py'到' .pyw'应该做的伎俩。
但是,如果您使用py2exe将脚本转换为可在任何Windows计算机上运行的独立应用程序,则需要对您的' setup.py进行以下更改。文件。
以下示例是使用Tkinter创建的简单python-GUI:
from distutils.core import setup
import py2exe
setup (console = ['tkinter_example.pyw'],
options = { 'py2exe' : {'packages':['Tkinter']}})
改变"控制台"在上面的代码中" windows" ..
from distutils.core import setup
import py2exe
setup (windows = ['tkinter_example.pyw'],
options = { 'py2exe' : {'packages':['Tkinter']}})
这只会打开Tkinter生成的GUI而没有控制台窗口。
答案 4 :(得分:5)
这会隐藏您的控制台。首先在代码中实现这一行,首先开始隐藏控制台。
import win32gui, win32con
The_program_to_hide = win32gui.GetForegroundWindow()
win32gui.ShowWindow(The_program_to_hide , win32con.SW_HIDE)
答案 5 :(得分:4)
一些额外的信息。对于需要Mohsen Haddadi在此主题中发布的win32gui解决方案的情况:
截至python 361,win32gui& win32con不是python std库的一部分。 要使用它们,需要安装pywin32包;现在可以通过pip。
pywin32软件包的更多背景信息位于:How to use the win32gui module with Python?。
此外,要在关闭窗口时应用谨慎,以免意外关闭前景中的任何窗口,分辨率可以按以下方式扩展:
try :
import win32gui, win32con;
frgrnd_wndw = win32gui.GetForegroundWindow();
wndw_title = win32gui.GetWindowText(frgrnd_wndw);
if wndw_title.endswith("python.exe"):
win32gui.ShowWindow(frgrnd_wndw, win32con.SW_HIDE);
#endif
except :
pass
答案 6 :(得分:-1)
一个装饰工厂(windows 版本,unix 版本应该更容易通过 os.fork
)
def deco_factory_daemon_subprocess(*, flag_env_var_name='__this_daemon_subprocess__', **kwargs_for_subprocess):
def deco(target):
@functools.wraps(target)
def tgt(*args, **kwargs):
if os.environ.get(flag_env_var_name) == __file__:
target(*args, **kwargs)
else:
os.environ[flag_env_var_name] = __file__
real_argv = psutil.Process(os.getpid()).cmdline()
exec_dir, exec_basename = path_split(real_argv[0])
if exec_basename.lower() == 'python.exe':
real_argv[0] = shutil.which('pythonw.exe')
kwargs = dict(env=os.environ, stdout=subprocess.PIPE, stderr=subprocess.PIPE, )
kwargs.update(kwargs_for_subprocess)
subprocess.Popen(real_argv, **kwargs)
return tgt
return deco
像这样使用它:
@deco_factory_daemon_subprocess()
def run():
...
def main():
run()