Why does Jython refuse to find my Java package?

前端 未结 3 1908
鱼传尺愫
鱼传尺愫 2020-12-17 17:09

I know it\'s something silly, but for some reason Jython refuses to find javax.swing. I\'m using Java 1.6.0_11. This is my start-up script:

@echo off

\"%J         


        
相关标签:
3条回答
  • 2020-12-17 17:50

    Most likely Jython is not scanning your packages. On startup, Jython tries to go through the jars and class files on its path and scan for Java packages. This is necessary because there is no way to look for Java packages by reflection. Package scanning can be deliberately turned off, or you could lack write privileges where it wants to write the cached information out see http://wiki.python.org/jython/PackageScanning for more. The best way to import Java classes is to do so explicitly class by class, like so:

    from javax.swing import JFrame
    

    This method should always work, even if package scanning is off or otherwise unable to work, and is the recommended approach (though it can be a bit tedious). If you do want to import packages (or if you want to do "from javax.swing import *" which also depends on package scanning - but is discouraged) you will need to figure out why your package scanning isn't working.

    0 讨论(0)
  • 2020-12-17 17:56

    I had similar issues, and it turns out that since the standalone Jython dist does not support caching, it also does not support the "import *" approach. This is not clearly documented anywhere in the official Jython docs, but I concluded this based on a number of different bug reports:

    • https://groups.google.com/forum/?hl=en&fromgroups=#!topic/robotframework-users/6ipB0DYJkvU
    • http://bugs.jython.org/issue1778514
    • http://bugs.jython.org/issue1422
    • http://bugs.jython.org/issue1692579

    Notable from that last link:

    So as Oti noted, in standalone you must do full imports to succeed.

    To fix your issue, use the non-standalone standard jython.jar generated by installing jython using the 'Standard' option.

    If you wanted to package and distribute jython.jar with your application, in case a user does not have Jython installed, then you will also need to copy/pase the complete "Lib" folder from the jython installation directory into whichever location you end up placing jython.jar. This enables access to the python stdlib which is not included in the standard jar file.

    UPDATE: After playing around more, I think I have a fix to enable "import *" type imports even when using the standalone jar. All that needs to be done is to enable caching!

    You can do this by either adding the following options to the jvm when running jython:

    -Dpython.cachedir.skip=false -Dpython.cachedir=DESIRED CACHE PATH

    (Note that the second argument is optional, and if left blank, a default value will be used)

    If you are having an issue running the InteractiveConsole embedded in an app (which is what my problem was) you can add these properties before initializing the console:

        Properties props = new Properties();
        props.put("python.cachedir.skip", "false");
        props.put("python.cachedir", "DESIRED CACHE PATH"); // again, this option is optional
        InteractiveConsole.initialize(System.getProperties(), props, new String[0]);
    
    0 讨论(0)
  • 2020-12-17 18:10

    I'm using Java 1.6.0_11

    No, you're using

    [Java HotSpot(TM) Client VM (Sun Microsystems Inc.)] on java1.6.0_10

    What happens if you delete the cachedir from the Jython distribution directory, and try again?

    Also, why are you explicitly setting the classpath that way? Why not simply

    java -jar jython.jar
    

    ?

    0 讨论(0)
提交回复
热议问题