當前位置: 首頁>>代碼示例>>Java>>正文


Java PythonInterpreter.exec方法代碼示例

本文整理匯總了Java中org.python.util.PythonInterpreter.exec方法的典型用法代碼示例。如果您正苦於以下問題:Java PythonInterpreter.exec方法的具體用法?Java PythonInterpreter.exec怎麽用?Java PythonInterpreter.exec使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.python.util.PythonInterpreter的用法示例。


在下文中一共展示了PythonInterpreter.exec方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: run

import org.python.util.PythonInterpreter; //導入方法依賴的package包/類
/**
 * The main thread for this class invoked by Thread.run()
 *
 * @see java.lang.Thread#run()
 */
public void run() {
    PythonInterpreter p = new PythonInterpreter();
    for (String name : this.locals.keySet()) {
        p.set(name, this.locals.get(name));
    }

    URL jarUrl = JythonServer.class.getProtectionDomain().getCodeSource().getLocation();
    String jarPath = jarUrl.getPath();
    if (jarUrl.getProtocol().equals("file")) {
        // If URL is of type file, assume that we are in dev env and set path to python dir.
        // else use the jar file as is
        jarPath = jarPath + "../../src/main/python/";
    }

    p.exec("import sys");
    p.exec("sys.path.append('" + jarPath + "')");
    p.exec("from debugserver import run_server");
    if (this.host == null) {
    	p.exec("run_server(port=" + this.port + ", locals=locals())");
    } else {
    	p.exec("run_server(port=" + this.port + ", host='" + this.host + "', locals=locals())");
    }
}
 
開發者ID:hksoni,項目名稱:SDN-Multicast,代碼行數:29,代碼來源:JythonServer.java

示例2: initializeInterperter

import org.python.util.PythonInterpreter; //導入方法依賴的package包/類
public void initializeInterperter(PythonInterpreter interpreter)
{
	boolean localsUninitialized = interpreter.getLocals() == initialLocals;
	if(localsUninitialized)
	{
		PyStringMap locals = new PyStringMap();
		interpreter.setLocals(locals);
		interpreter.exec(scripts.get(PythonTransformationHelper.getImportStatements()));
		interpreter.exec(scripts.get(PythonTransformationHelper.getGetValueDefStatement()));
		interpreter.exec(scripts.get(PythonTransformationHelper.getIsEmptyDefStatement()));
		interpreter.exec(scripts.get(PythonTransformationHelper.getHasSelectedRowsStatement()));
		interpreter.exec(scripts.get(PythonTransformationHelper.getGetValueFromNestedColumnByIndexDefStatement()));
		interpreter.exec(scripts.get(PythonTransformationHelper.getRowIndexDefStatement()));
		interpreter.exec(scripts.get(PythonTransformationHelper.getVDefStatement()));
	}
	if(localsUninitialized ||(!libraryHasBeenLoaded || reloadLibrary))
	{
		importUserScripts(interpreter);
	}

}
 
開發者ID:therelaxist,項目名稱:spring-usc,代碼行數:22,代碼來源:PythonRepository.java

示例3: loadAvailableLexers

import org.python.util.PythonInterpreter; //導入方法依賴的package包/類
public List<LexerInfo> loadAvailableLexers(PyGateway gateway) {
    PythonInterpreter interpreter = gateway.getInterpreter();

    // Simple use Pygments as you would in Python
    interpreter.exec(""
            + "from pygments.lexers import get_all_lexers\n"
            + "result = get_all_lexers()");

    PyGenerator result = (PyGenerator) interpreter.get("result");
    ArrayList<LexerInfo> infos = Lists.newArrayList();
    for (Object o : result) {
        PyTuple tuple = (PyTuple) o;
        String name = (String) tuple.get(0);
        List<String> aliases = Lists.newArrayListWithCapacity(3);
        for (Object alias : (PyTuple) tuple.get(1)) {
            String str = (String) alias;
            aliases.add(str);
        }
        LexerInfo info = new LexerInfo(name, aliases);
        infos.add(info);
    }
    return infos;
}
 
開發者ID:Arnauld,項目名稱:gutenberg,代碼行數:24,代碼來源:Lexers.java

示例4: NifiClientFactory

import org.python.util.PythonInterpreter; //導入方法依賴的package包/類
public NifiClientFactory() {
    /*StringBuilder sb = new StringBuilder();
    sb.append(System.getProperty("java.class.path"));
    sb.append(":").append("~/workplace/echo/src/main/nifi");
    Properties props = new Properties();
    props.setProperty("python.path", sb.toString());
    props.setProperty("python.verbose", "error");

    PythonInterpreter.initialize(System.getProperties(), props, new String[0]);*/

    PythonInterpreter interpreter = new PythonInterpreter();
    //interpreter.exec("import os\nprint os.getcwd()");
    interpreter.exec("import sys\nif '' not in sys.path:\n    sys.path.append(\"\")");
    interpreter.exec("from modules.json2pojo.src.main.python.DefaultNifiClient import DefaultNifiClient");
    nifiClientClass = interpreter.get("DefaultNifiClient");
}
 
開發者ID:dream-lab,項目名稱:echo,代碼行數:17,代碼來源:NifiClientFactory.java

示例5: testPyJenkinsInterpreter

import org.python.util.PythonInterpreter; //導入方法依賴的package包/類
@Test
public void testPyJenkinsInterpreter() throws Exception {
    BuildContext context = newSimpleBuildContext();
    PythonInterpreter pyjenkins = PythonFactory.newPyJenkinsInterpreter(context, newSimpleBuildConfig());

    String script =
        "from pyjenkins import *\n" +
        "class Foo(PyJenkinsBuild):\n" +
        "  def run(self):\n" +
        "    return Result.NOT_BUILT\n" +
        "register_pybuild( Foo() )";
    pyjenkins.exec(script);

    PyJenkinsBuild pybuild = context.pybuild;
    assertNotNull("should have registered pybuild", pybuild);

    Result result = pybuild.run();
    assertEquals("should return the specified result", Result.NOT_BUILT, result);
}
 
開發者ID:tanium,項目名稱:pyjenkins,代碼行數:20,代碼來源:PythonFactoryTest.java

示例6: testPyJenkinsBuildConfigFalse

import org.python.util.PythonInterpreter; //導入方法依賴的package包/類
@Test
public void testPyJenkinsBuildConfigFalse() throws Exception {
    BuildContext context = newSimpleBuildContext();
    BuildConfig config = new BuildConfig(false, false);
    PythonInterpreter pyjenkins = PythonFactory.newPyJenkinsInterpreter(context, config);

    String script =
        "from pyjenkins import *\n" +
        "class Foo(PyJenkinsBuild):\n" +
        "  def run(self):\n" +
        "    if is_pull_request_build() or is_release_build():\n" +
        "      return Result.FAILURE\n" +
        "    return Result.SUCCESS\n" +
        "register_pybuild( Foo() )";
    pyjenkins.exec(script);

    PyJenkinsBuild pybuild = context.pybuild;
    assertNotNull("should have registered pybuild", pybuild);

    Result result = pybuild.run();
    assertEquals("should return the specified result", Result.SUCCESS, result);
}
 
開發者ID:tanium,項目名稱:pyjenkins,代碼行數:23,代碼來源:PythonFactoryTest.java

示例7: testPyJenkinsBuildConfigReleaseBuild

import org.python.util.PythonInterpreter; //導入方法依賴的package包/類
@Test
public void testPyJenkinsBuildConfigReleaseBuild() throws Exception {
    BuildContext context = newSimpleBuildContext();
    BuildConfig config = new BuildConfig(false, true);
    PythonInterpreter pyjenkins = PythonFactory.newPyJenkinsInterpreter(context, config);

    String script =
        "from pyjenkins import *\n" +
        "class Foo(PyJenkinsBuild):\n" +
        "  def run(self):\n" +
        "    if is_pull_request_build() or not is_release_build():\n" +
        "      return Result.FAILURE\n" +
        "    return Result.SUCCESS\n" +
        "register_pybuild( Foo() )";
    pyjenkins.exec(script);

    PyJenkinsBuild pybuild = context.pybuild;
    assertNotNull("should have registered pybuild", pybuild);

    Result result = pybuild.run();
    assertEquals("should return the specified result", Result.SUCCESS, result);
}
 
開發者ID:tanium,項目名稱:pyjenkins,代碼行數:23,代碼來源:PythonFactoryTest.java

示例8: Interpretor

import org.python.util.PythonInterpreter; //導入方法依賴的package包/類
public Interpretor() {
	PythonInterpreter interpreter = new PythonInterpreter();
	
	String dirpathString = ServletContextParameterMap.getParameterValue(ContextParameter.WEBAPP_PATH) + 
								"/" + ServletContextParameterMap
								.getParameterValue(ContextParameter.PYTHON_SCRIPTS_DIRECTORY);
	
								;
	if(dirpathString == null || dirpathString.toString().length() <= 1) {
		dirpathString = "../karma-web/src/main/webapp/resources/pythonCleaningscripts";
	} 
	logger.info("Setting Python Scripts Directory for karma-cleaning: " + dirpathString);
	
	interpreter.exec("import sys");
	// /Users/bowu/projects/IDCT/src/edu/isi/karma/cleaning
	interpreter.exec("sys.path.append('" + dirpathString + "')");
	interpreter.exec("from FunctionList import *");
	interpreter.exec("from Interpreter import *");
	// interpreter.exec("print sys.path");
	interpreterClass = interpreter.get("Interpreter");
}
 
開發者ID:therelaxist,項目名稱:spring-usc,代碼行數:22,代碼來源:Interpretor.java

示例9: test_jython_loading

import org.python.util.PythonInterpreter; //導入方法依賴的package包/類
@Test
public void test_jython_loading() throws Throwable {
  CodeLoader loader = new CodeLoader();
  PythonInterpreter interpreter = loader.jython("check");

  PyObject object = interpreter.get("truth");
  assertTrue(object instanceof PyFunction);
  PyFunction fun = (PyFunction) object;
  assertEquals(new PyInteger(42), fun.__call__());

  object = interpreter.get("incr");
  assertTrue(object instanceof PyFunction);
  fun = (PyFunction) object;
  assertEquals(new PyInteger(3), fun.__call__(new PyInteger(2)));

  fun = (PyFunction) interpreter.get("foo");
  interpreter.exec("from org.gololang.microbenchmarks.support import Foo");
  PyObject foo = interpreter.eval("Foo()");
  assertEquals(new PyString("foo"), fun.__call__(foo));
}
 
開發者ID:golo-lang,項目名稱:golo-jmh-benchmarks,代碼行數:21,代碼來源:CodeLoaderTest.java

示例10: execute

import org.python.util.PythonInterpreter; //導入方法依賴的package包/類
public void execute( ExecutionContext executionContext ) throws ParsingException, ExecutionException
{
	PythonInterpreter pythonInterpreter = adapter.getPythonInterpreter( executionContext, executable );

	try
	{
		PyCode pythonCode = this.pythonCode;
		if( pythonCode != null )
			pythonInterpreter.exec( pythonCode );
		else
			// We're using a stream because PythonInterpreter does not
			// expose a string-based method that also accepts a filename.
			pythonInterpreter.execfile( new ByteArrayInputStream( sourceCode.getBytes() ), executable.getDocumentName() );
	}
	catch( Exception x )
	{
		throw JythonAdapter.createExecutionException( executable.getDocumentName(), startLineNumber, x );
	}
	finally
	{
		JythonAdapter.flush( pythonInterpreter, executionContext );
	}
}
 
開發者ID:tliron,項目名稱:scripturian,代碼行數:24,代碼來源:JythonProgram.java

示例11: RunButtonActionPerformed

import org.python.util.PythonInterpreter; //導入方法依賴的package包/類
private void RunButtonActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_RunButtonActionPerformed
    this.PythonOutput.setText("");

    String python = this.PythonText.getText();
    //python.replaceAll("\t", "    ");

    /* 
     try {
     File f = new File("filename.txt") ;
     PrintWriter out = new PrintWriter(f);
     out.write(python);
     out.close();
     // open it
     Desktop.getDesktop().open(f) ;
     } catch (Exception ex) {
     ex.printStackTrace();
     }
     */
    PythonInterpreter interp = new PythonInterpreter();

    interp.setIn(System.in);
    interp.setOut(System.out);

    interp.exec(python);
}
 
開發者ID:cornerpirate,項目名稱:ReportCompilerSource,代碼行數:26,代碼來源:ShowNotesWindow.java

示例12: apply

import org.python.util.PythonInterpreter; //導入方法依賴的package包/類
@Override
public ConstructionList apply( ConstructionList parameters, AttributeMap attrs, ConstructionChanges effects )
throws Command.Failure
{
    ConstructionList result = new ConstructionList();
    if ( parameters .size() != 1 )
        throw new Failure( "start parameter must be a single connector" );
    Construction c = parameters .get( 0 );
    if ( ! ( c instanceof Point ) )
        throw new Failure( "start parameter must be a connector" );
    Point pt1 = (Point) c;
    String script = (String) attrs .get( SCRIPT_ATTR );
    final Symmetry symm = (Symmetry) attrs .get( CommandTransform.SYMMETRY_GROUP_ATTR_NAME );

    ZomicVirtualMachine builder = new ZomicVirtualMachine( pt1, effects, symm );

    PythonInterpreter interp = new PythonInterpreter();
    interp .set( "zomicVM", builder );
    interp .exec( script );

    result .addConstruction( builder .getLastPoint() );
    return result;
}
 
開發者ID:vZome,項目名稱:vzome-core,代碼行數:24,代碼來源:CommandExecutePythonScript.java

示例13: getJavaObjectFromJythonFile

import org.python.util.PythonInterpreter; //導入方法依賴的package包/類
public Object getJavaObjectFromJythonFile(String interfaceName, String pathToJythonModule)
{
    Object javaObject = null;
    
    PythonInterpreter interpreter = cacheInterpreter(pathToJythonModule);
    
    String tempName = pathToJythonModule.substring(pathToJythonModule.lastIndexOf("/") + 1);
    tempName = tempName.substring(0, tempName.indexOf("."));
    System.out.println(tempName);
    String instanceName = tempName.toLowerCase();
    String javaClassName = tempName.substring(0, 1).toUpperCase() + tempName.substring(1);
    String objectDef = "=" + javaClassName + "()";
    interpreter.exec(instanceName + objectDef);
    try
    {
        Class<?> JavaInterface = Class.forName(interfaceName);
        javaObject = interpreter.get(instanceName).__tojava__(JavaInterface);
    }
    catch (ClassNotFoundException ex)
    {
        ex.printStackTrace(); // Add logging here36.
    }
    return javaObject;
}
 
開發者ID:liulhdarks,項目名稱:darks-orm,代碼行數:25,代碼來源:JythonFactory.java

示例14: run

import org.python.util.PythonInterpreter; //導入方法依賴的package包/類
/**
 * The main thread for this class invoked by Thread.run()
 *
 * @see java.lang.Thread#run()
 */
public void run() {
    PythonInterpreter p = new PythonInterpreter();
    for (String name : this.locals.keySet()) {
        p.set(name, this.locals.get(name));
    }

    URL jarUrl = JythonServer.class.getProtectionDomain().getCodeSource().getLocation();
    String jarPath = jarUrl.getPath();
    if (jarUrl.getProtocol().equals("file")) {
        // If URL is of type file, assume that we are in dev env and set path to python dir.
        // else use the jar file as is
        jarPath = jarPath + "../../src/main/python/";
    }

    p.exec("import sys");
    p.exec("sys.path.append('" + jarPath + "')");
    p.exec("from debugserver import run_server");
    p.exec("run_server(" + this.port + ", '0.0.0.0', locals())");
}
 
開發者ID:smartenit-eu,項目名稱:smartenit,代碼行數:25,代碼來源:JythonServer.java

示例15: main

import org.python.util.PythonInterpreter; //導入方法依賴的package包/類
public static void main(String... args) {
    PythonInterpreter pythonInterpreter = new PythonInterpreter();

    int count = 0;
    for(String arg : args) {
        try {
            count++;
            pythonInterpreter.set("number" + count, new Integer(arg));
        }
        catch (NumberFormatException e) {
            System.err.println(arg + " is not a number!");
            count--;
        }
    }
    pythonInterpreter.set("sum", 0);
    for(int i = 1; i <= count; i++) {
        pythonInterpreter.exec(String.format("sum += %s", "number"+i));
    }
    PyObject sum = pythonInterpreter.get("sum");
    System.out.println("The result is: " + sum.toString());
}
 
開發者ID:ghajba,項目名稱:JaPy,代碼行數:22,代碼來源:PythonCalling.java


注:本文中的org.python.util.PythonInterpreter.exec方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。