Python PSS/E получает вывод как переменную
Я энергетик, и я часто использую python в программе PSS/E. Я сложен и хочу твоей помощи как программистов. У меня есть этот маленький код:
import os,sys
PSSE_LOCATION = r"C:\Program Files\PTI\PSSE33\PSSBIN"
sys.path.append(PSSE_LOCATION)
os.environ['PATH'] = os.environ['PATH'] + ';' + PSSE_LOCATION
import psspy
import redirect
redirect.psse2py()
#--------------------------------
# PSS/E Saved case
CASE = r"""D:\xxx\Desktop\TESTING\SUMMAX.sav"""
if __name__ == '__main__':
psspy.psseinit(2000)
psspy.case(CASE)
psspy.fnsl(
options1=0, # disable tap stepping adjustment.
options5=0, # disable switched shunt adjustment.
)
psspy.fdns([0,0,0,1,1,0,99,0])
psspy.area_2(0,1,1)
Код redirect.psse2py()
печатает отчет о программе в консоли. Можете ли вы помочь мне получить эти результаты как переменные?
2 ответа
Решение
Учитывая, что я не знаю много о PSSE, вы можете попробовать следующее:
import sys
import io
out, err = io.StringIO(), io.StringIO()
sys.stdout = out
sys.stderr = err
# rest of your code here
# once your code is finished
results = out.getvalue()
errors = err.getvalue()
Мое любимое решение до сих пор основано на ответе @JF Себастьяна. Перенаправить стандартный вывод в файл на Python?,
С использованием psspy.report_output()
и связанные функции на первый взгляд казались лучшим вариантом, но они немного болезненны, потому что вы можете писать только в файл, а не StringIO
буфер.
Вот полный пример:
import contextlib
import sys
# Auto-magically setup PSSE environment.
# You can do this step the hard way if you want
import pssepath
pssepath.add_pssepath()
import psspy
import redirect
redirect.psse2py()
psspy.psseinit(50000)
@contextlib.contextmanager
def redirect_stdout(new_target):
old_target, sys.stdout = sys.stdout, new_target # replace sys.stdout
try:
yield new_target # run some code with the replaced stdout
finally:
sys.stdout = old_target # restore to the previous value
import StringIO
f = StringIO.StringIO()
print "before redirect"
with redirect_stdout(f):
psspy.report('123xxx(report)')
psspy.alert('abcyyy(alert)')
psspy.progress('foobar(progress)')
f.seek(0)
var = f.read()
print "after redirect"
print "var: %s" % var
который печатает:
< snip PSSE init copyright header>
before redirect
after redirect
var: 123xxx(report)
abcyyy(alert)
foobar(progress)