2009-07-10 4 views
2

私はJythonで開発されたアプリケーションを使用しています。 inspect.pyを使用しようとすると、エラーメッセージが表示されます。Jython内でinspect.pyを使用する際の問題

私のコードは、私は、この使用してpython.exeを実行すると、問題がないこの

import inspect,os,sys,pprint,imp 
def handle_stackframe_without_leak(getframe): 
    frame = inspect.currentframe() 
    try: 
     function = inspect.getframeinfo(getframe) 
     print inspect.getargvalues(getframe) 
    finally: 
     del frame 
# 
def raja(a): 
    handle_stackframe_without_leak(inspect.currentframe()) 
    print a 
# 
def callraja(): 
    handle_stackframe_without_leak(inspect.currentframe()) 
    raja("[email protected]") 
# 
callraja() 
raja("[email protected]") 
# 

のようになります。しかし、これを使用してアプリ内で次のエラーが発生する

File "C:\Program Files\jython221ondiffjava\Lib\inspect.py", line 722, in getframeinfo 
File "C:\Program Files\jython221ondiffjava\Lib\inspect.py", line 413, in findsource 
File "C:\Program Files\jython221ondiffjava\Lib\sre.py", line 179, in compile 
File "C:\Program Files\jython221ondiffjava\Lib\sre.py", line 227, in _compile 
File "C:\Program Files\jython221ondiffjava\Lib\sre_compile.py", line 437, in compile 
File "C:\Program Files\jython221ondiffjava\Lib\sre_compile.py", line 421, in _code 
File "C:\Program Files\jython221ondiffjava\Lib\sre_compile.py", line 143, in _compile 
ValueError: ('unsupported operand type', 'branch') 

    at org.python.core.Py.makeException(Unknown Source) 
    at sre_compile$py._compile$1(C:\Program Files\jython221ondiffjava\Lib\sre_compile.py:143) 
    at sre_compile$py.call_function(C:\Program Files\jython221ondiffjava\Lib\sre_compile.py) 
    at org.python.core.PyTableCode.call(Unknown Source) 
    at org.python.core.PyTableCode.call(Unknown Source) 
    at org.python.core.PyFunction.__call__(Unknown Source) 
    at sre_compile$py._code$11(C:\Program Files\jython221ondiffjava\Lib\sre_compile.py:421) 
    at sre_compile$py.call_function(C:\Program Files\jython221ondiffjava\Lib\sre_compile.py) 
    at org.python.core.PyTableCode.call(Unknown Source) 
    at org.python.core.PyTableCode.call(Unknown Source) 
    at org.python.core.PyFunction.__call__(Unknown Source) 
    at sre_compile$py.compile$12(C:\Program Files\jython221ondiffjava\Lib\sre_compile.py:437) 
    at sre_compile$py.call_function(C:\Program Files\jython221ondiffjava\Lib\sre_compile.py) 
    at org.python.core.PyTableCode.call(Unknown Source) 
    at org.python.core.PyTableCode.call(Unknown Source) 
    at org.python.core.PyFunction.__call__(Unknown Source) 
    at org.python.core.PyObject.invoke(Unknown Source) 
    at sre$py._compile$13(C:\Program Files\jython221ondiffjava\Lib\sre.py:227) 
    at sre$py.call_function(C:\Program Files\jython221ondiffjava\Lib\sre.py) 
    at org.python.core.PyTableCode.call(Unknown Source) 
    at org.python.core.PyTableCode.call(Unknown Source) 
    at org.python.core.PyTableCode.call(Unknown Source) 
    at org.python.core.PyFunction.__call__(Unknown Source) 
    at sre$py.compile$8(C:\Program Files\jython221ondiffjava\Lib\sre.py:179) 
    at sre$py.call_function(C:\Program Files\jython221ondiffjava\Lib\sre.py) 
    at org.python.core.PyTableCode.call(Unknown Source) 
    at org.python.core.PyTableCode.call(Unknown Source) 
    at org.python.core.PyTableCode.call(Unknown Source) 
    at org.python.core.PyFunction.__call__(Unknown Source) 
    at org.python.core.PyObject.invoke(Unknown Source) 
    at inspect$py.findsource$24(C:\Program Files\jython221ondiffjava\Lib\inspect.py:413) 
    at inspect$py.call_function(C:\Program Files\jython221ondiffjava\Lib\inspect.py) 
    at org.python.core.PyTableCode.call(Unknown Source) 
    at org.python.core.PyTableCode.call(Unknown Source) 
    at org.python.core.PyFunction.__call__(Unknown Source) 
    at inspect$py.getframeinfo$54(C:\Program Files\jython221ondiffjava\Lib\inspect.py:722) 
    at inspect$py.call_function(C:\Program Files\jython221ondiffjava\Lib\inspect.py) 
    at org.python.core.PyTableCode.call(Unknown Source) 
    at org.python.core.PyTableCode.call(Unknown Source) 
    at org.python.core.PyTableCode.call(Unknown Source) 
    at org.python.core.PyFunction.__call__(Unknown Source) 
    at org.python.core.PyObject.invoke(Unknown Source) 
    at custom$py.handle_stackframe_without_leak$4(C:\Program Files\<my app>\jars\custom.py:29) 
    at custom$py.call_function(C:\Program Files\<my app>\.\jars\custom.py) 
    at org.python.core.PyTableCode.call(Unknown Source) 
    at org.python.core.PyTableCode.call(Unknown Source) 
    at org.python.core.PyFunction.__call__(Unknown Source) 
    at definitions$py.gotonotificationprofile$122(C:\Program Files\<my app>\.\jars\definitions.py:1738) 
    at definitions$py.call_function(C:\Program Files\<my app>\.\jars\definitions.py) 
    at org.python.core.PyTableCode.call(Unknown Source) 
    at org.python.core.PyTableCode.call(Unknown Source) 
    at org.python.core.PyFunction.__call__(Unknown Source) 
    at notificationcases$py.A003$2(C:\Program Files\<my app>\.\jars\notificationcases.py:143) 
    at notificationcases$py.call_function(C:\Program Files\<my app>\.\jars\notificationcases.py) 
    at org.python.core.PyTableCode.call(Unknown Source) 
    at org.python.core.PyTableCode.call(Unknown Source) 
    at org.python.core.PyFunction.__call__(Unknown Source) 
    at org.python.pycode._pyx171.f$0(003:8) 
    at org.python.pycode._pyx171.call_function(003) 
    at org.python.core.PyTableCode.call(Unknown Source) 
    at org.python.core.PyCode.call(Unknown Source) 
    at org.python.core.Py.runCode(Unknown Source) 
    at org.python.util.PythonInterpreter.execfile(Unknown Source) 

助けていただければ幸いです。

おかげ Rajasankar

答えて

0

これはhttp://grinder.sourceforge.net/faq.html#re-problemsを助けるかもしれません。クイックチェックのために

、findsource方法でimport reを追加してみてください(C:\プログラムファイル\ jython221ondiffjava \ Libの\ inspect.py)


def findsource(object): 
    """Return the entire source file and starting line number for an object. 
    (...snip...)""" 
    import re 
    file = getsourcefile(object) or getfile(object) 

...しかし、

を何かを約束することはできません
1

Jythonを使ってコマンドラインでプログラムを実行しようとしましたか? Jython 2.2.1またはJython 2.5.0でプログラムを実行すると、Pythonと同じ出力が得られます。

+0

私はPythonを試しました。私はこれを試してみる。 – Rajasankar

+0

アプリが動いています。私は、アプリケーション内のreモジュールで作業することができません。バージョンをチェックします。 – Rajasankar

関連する問題