1、python代码没错但运洞腔槐行不出来的原因:
某项目中使用python脚本方式将日志文件中纳友的数据持续的转换格式输出到另一文件中以供其他日志分析应用使用。但是当后台运行采取重定向方式输出到某一文件时,发现并没有内容输出,命令如下:
pythonxxx.py>xxx.log&
测试发现,当前台直接输出到终端时正常,使用后台运行重定向的方式输出到文件中时无法输出。
2、解决办法:
发现是在程序运行时,输出有缓存,只有当程序运行结束或者缓冲区满后才会输出。因为程序是一致在运行的所以不可能等待程序结束在输出。并且要求是有实时性的所以等缓冲区满输出的方式也不可取。
所以采用在python运行时加上-u参数,如:
python-uxxx.py>xxx.log&
-u参数的意义是不使用缓冲的方式输入输出
详细如下:
Forcestdin,stdoutandstderrtobetotallyunbuffered.Onsystemswhereitmatters,alsoputstdin,stdoutandstderrinbinarymode.Notethatthereisinternalbufferinginxreadlines(),readlines()andfile-objectiterators("forlineinsys.stdin”)whichisnotinfluencedbythisoption.Toworkaroundthis,youwillwanttouse"sys.stdin.readline()”insidea"while1:”loop.
补充知识:python中运行代码时没有报错但是也没有输出而且还有exitcode0的结束标志
如下所示:
f=open("passwd.txt",'r')
print(f.read(4))
f.close()
这是想要执行的代码
passwd.txt中的内容
ntp:x:38:38::/etc/ntp:/sbin/nologin
apache:x:48:48:Apache:/var/www:/sbin/nologin
saslauth:x:498:76:Saslauthduser:/var/empty/saslauth:/sbin/nologin
postfix:x:89:89::/var/spool/postfix:/sbin/nologin
gdm:x:42:42::/var/lib/gdm:/sbin/nologin
pulse:x:497:496:PulseAudioSystemDaemon:/var/run/pulse:/sbin/nologin
但是输出的结果是
Processfinishedwithexitcode0
后来排查发现原来是解释器的问题
我之前使用的解释器是pycharm提供的虚拟解释器
#####如何查看解释器
点file?C>newprojects
如果选择的是2就是使用了pycharm提供的虚拟解释器,又因为passwd.txt文件不是在虚拟环境中的所以就没有输出。
点击圆世3然后选择你已经下载好的解释器即可。
以上就是今天的分享了,希望可以帮助到大家。
pyinstaller将Python脚本打包成可执行程序,正迟使在没有Python环境的机器上运行使用命令pip install pyinstaller即可
基本语法:
pyinstaller options myscript.py
常用的可选参数如下:
--onefile 将结果打包成一个可执行文件
--onedir 将所有结果打包到一个文件夹中,该文件夹包括一个可执行文件和可执行文件执行时需要的依赖文件(默认余亏)
--paths=DIR 设置导入路径
--distpath=DIR 设置将打包的结果文件放竖清神置的路径
--specpath=DIR 设置将spec文件放置的路径
--windowed 使用windows子系统执行,不会打开命令行(只对windows有效)
--nowindowed 使用控制台子系统执行(默认)(只对windows有效)
--icon=<FILE.ICO>将file.ico添加为可执行文件的资源(只对windows有效)
如pyinstaller --paths="D:\Queena" guess_exe.py
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)