本文整理匯總了Java中org.python.util.PythonInterpreter.get方法的典型用法代碼示例。如果您正苦於以下問題:Java PythonInterpreter.get方法的具體用法?Java PythonInterpreter.get怎麽用?Java PythonInterpreter.get使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類org.python.util.PythonInterpreter
的用法示例。
在下文中一共展示了PythonInterpreter.get方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: 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;
}
示例2: 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");
}
示例3: getCount
import org.python.util.PythonInterpreter; //導入方法依賴的package包/類
public double getCount(int[] query) {
// convert the int[] query to PyList<PyInteger> pyQuery
// the input java query is like [0, 2, 1, -1], the converted python query is like [1, 3, 2]
List<PyInteger> pyQueryList = new ArrayList<PyInteger>();
for (int eachValue : query)
if (eachValue != -1)
pyQueryList.add(new PyInteger(eachValue+1));
PyList pyQuery = new PyList(pyQueryList);
PythonInterpreter interpreter = new PythonInterpreter();
interpreter.execfile("/media/uraplutonium/Workstation/Workspace/teabag-ml/src/main/java/teabagml/adtree/PySparseADTree.py");
PyFunction getCountFunc = (PyFunction)interpreter.get("getCount", PyFunction.class);
PyInteger pyCount = (PyInteger)(getCountFunc.__call__(contab, pyQuery));
double count = (double)(pyCount.getValue());
/*
System.out.print("Query: ");
for (int eachValue : query) {
System.out.print(eachValue + ' ');
}
System.out.println("\t Count: " + count);
*/
return count;
}
示例4: PyDataset
import org.python.util.PythonInterpreter; //導入方法依賴的package包/類
public PyDataset(String filePath, boolean symbolic, boolean labelled) {
// BEWEAR: symbolic and labelled are NOT used
this.symbolic = symbolic;
this.labelled = labelled;
PythonInterpreter interpreter = new PythonInterpreter();
interpreter.execfile("/media/uraplutonium/Workstation/Workspace/teabag-ml/src/main/java/teabagml/adtree/PySparseADTree.py");
PyFunction loadFileFunc = (PyFunction)interpreter.get("loadFile", PyFunction.class);
fileTuple = (PyTuple)(loadFileFunc.__call__(new PyString(filePath)));
// todo extract dimension, dataSize, arity from fileTuple
PyInteger pyArityLength = (PyInteger)(fileTuple.pyget(1));
PyList pyArityList = (PyList)(fileTuple.pyget(2));
PyInteger pyRecordsLength = (PyInteger)(fileTuple.pyget(3));
this.dimension = pyArityLength.getValue();
this.dataSize = pyRecordsLength.getValue();
PyObject[] pyArityArray = pyArityList.getArray();
String[] arityNames = new String[dimension];
int[] arityArray = new int[dimension];
for (int i=0; i<dimension; i++) {
arityArray[i] = ((PyInteger)(pyArityArray[i])).getValue();
arityNames[i] = Integer.toString(arityArray[i]);
}
arity = new Arity(dimension, arityNames, arityArray);
System.out.println("file loaded.");
}
示例5: prepare
import org.python.util.PythonInterpreter; //導入方法依賴的package包/類
@Setup(Level.Trial)
public void prepare() {
PythonInterpreter interpreter = new CodeLoader().jython("dispatch");
dispatcher = (PyFunction) interpreter.get("dispatch");
MonomorphicState monomorphicState = new MonomorphicState();
monomorphicState.prepare();
monomorphicArray = new PyArray(Object.class, monomorphicState.data);
TriMorphicState triMorphicState = new TriMorphicState();
triMorphicState.prepare();
trimorphicArray = new PyArray(Object.class, triMorphicState.data);
PolyMorphicState polyMorphicState = new PolyMorphicState();
polyMorphicState.prepare();
polymorphicArray = new PyArray(Object.class, polyMorphicState.data);
}
示例6: 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));
}
示例7: enter
import org.python.util.PythonInterpreter; //導入方法依賴的package包/類
@Override
public Object enter( String entryPointName, Executable executable, ExecutionContext executionContext, Object... arguments ) throws NoSuchMethodException, ParsingException, ExecutionException
{
entryPointName = toPythonStyle( entryPointName );
PythonInterpreter pythonInterpreter = (PythonInterpreter) executionContext.getAttributes().get( JYTHON_INTERPRETER );
Py.setSystemState( pythonInterpreter.getSystemState() );
PyObject method = pythonInterpreter.get( entryPointName );
if( method == null )
throw new NoSuchMethodException( entryPointName );
try
{
PyObject[] pythonArguments = Py.javas2pys( arguments );
PyObject r = method.__call__( pythonArguments );
return r.__tojava__( Object.class );
}
catch( Exception x )
{
throw JythonAdapter.createExecutionException( executable.getDocumentName(), 0, x );
}
finally
{
flush( pythonInterpreter, executionContext );
}
}
示例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");
}
示例9: 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());
}
示例10: loadPythonScript
import org.python.util.PythonInterpreter; //導入方法依賴的package包/類
@SuppressWarnings("unchecked")
private <T> T loadPythonScript(String scriptPythonType, Class<T> scriptJavaType, PyObject[] constructorArgs, PythonInterpreter interpreter)
throws PythonException {
PyObject scriptPythonTypeObject = interpreter.get(scriptPythonType);
if (scriptPythonTypeObject == null) {
return null;
}
PyObject scriptPythonTypeClass;
try {
scriptPythonTypeClass = scriptPythonTypeObject.__call__(constructorArgs);
} catch (Exception ex) {
log.error("Failed to initialize python class", ex.getMessage());
throw new PythonException(String.format("Failed to initialize python class '%s'", scriptPythonType), ex);
}
Object scriptJavaClass = scriptPythonTypeClass.__tojava__(scriptJavaType);
if (!ReflectHelper.assignableFrom(scriptJavaClass.getClass(), scriptJavaType)) {
return null;
}
return (T) scriptJavaClass;
}
示例11: evalLookupLexer
import org.python.util.PythonInterpreter; //導入方法依賴的package包/類
private Object evalLookupLexer(PyGateway gateway, String alias, Object notFoundFallback) {
Object result;
try {
PythonInterpreter interpreter = gateway.getInterpreter();
interpreter.set("alias", alias);
interpreter.exec(""
+ "from pygments.lexers import get_lexer_by_name\n"
+ "result = get_lexer_by_name(alias)");
result = interpreter.get("result");
} catch (PyException e) {
log.warn("Unable to find Pygments lexer for alias '{}'", alias);
result = notFoundFallback;
}
return result;
}
示例12: loadFromFile
import org.python.util.PythonInterpreter; //導入方法依賴的package包/類
/**
* Loads a module from a Python file that contains a class with the <b>SAME</b> name as the file.
* The class must extend {@link ExternalModule}.
*
* @param f the file to load the {@link org.freecode.irc.votebot.api.ExternalModule} from
* @return the {@link ExternalModule} loaded, or <tt>null</tt>
* @throws IOException if the file was not found
* @throws ScriptException if the script failed to load
*/
public ExternalModule loadFromFile(final File f) throws IOException, ScriptException {
if (f == null || !f.exists()) {
throw new IOException("Invalid file");
}
if (f.getName().endsWith(".py")) {
PythonInterpreter interpreter = new PythonInterpreter();
String clzName = f.getName().replace(".py", "");
interpreter.exec(String.format("from %s import %s", clzName, clzName));
PyObject pyClass = interpreter.get(clzName);
PyObject buildObject = pyClass.__call__();
ExternalModule ext = (ExternalModule) buildObject.__tojava__(ExternalModule.class);
ext.setFvb(fvb);
ext.setExtName(clzName);
interpreter.cleanup();
return ext;
}
return null;
}
示例13: main
import org.python.util.PythonInterpreter; //導入方法依賴的package包/類
public static void main(String[] args) {
String directory = System.getProperty("user.home") + File.separator + ".fvb-modules";
File dir = new File(directory);
if (dir.exists()) {
try {
Properties props = new Properties();
props.setProperty("python.path", directory);
PythonInterpreter.initialize(System.getProperties(), props, new String[]{""});
PythonInterpreter interpreter = new PythonInterpreter();
// PyCode code = interpreter.compile(new FileReader(new File(directory, "TestModule.py")));
interpreter.exec("from TestModule import TestModule");
//interpreter.eval(code);
// System.out.println(interpreter.getLocals());
PyObject object = interpreter.get("TestModule");
PyObject buildObject = object.__call__();
ExternalModule ext = (ExternalModule) buildObject.__tojava__(ExternalModule.class);
System.out.println(ext.getName());
} catch (Exception e) {
e.printStackTrace();
}
}
}
示例14: checkImplements
import org.python.util.PythonInterpreter; //導入方法依賴的package包/類
/**
* Check that a type implements a Java interface
*
* @param langType type with langauge
* @param interfaceClass java interface class
* @param interpreter PythonInterpreter
*/
private static void checkImplements(LanguageAndType langType,
Class interfaceClass, PythonInterpreter interpreter) {
switch (langType.getLanguage()) {
case JAVA:
checkArgument(interfaceClass.isAssignableFrom(langType.getJavaClass()),
langType.getJavaClass().getSimpleName() + " needs to implement " +
interfaceClass.getSimpleName());
break;
case JYTHON:
PyObject pyClass = interpreter.get(langType.getJythonClassName());
PyObject pyObj = pyClass.__call__();
Object converted = pyObj.__tojava__(interfaceClass);
checkArgument(!Py.NoConversion.equals(converted),
"Jython class " + langType.getJythonClassName() +
" does not implement " + interfaceClass.getSimpleName() +
" interface");
break;
default:
throw new IllegalArgumentException("Don't know how to handle " +
"language " + langType.getLanguage());
}
}
示例15: loadJython
import org.python.util.PythonInterpreter; //導入方法依賴的package包/類
public static synchronized Object loadJython(String tagName, String[] armNames, Element config)
throws Exception {
Class mustImplement = load(tagName.substring("jython".length()), armNames);
if (getElement(config, "inline") != null) {
String jythonCode = getNestedText(getElement(config, "inline"));
return inlineJython(tagName+pythonClassNum++, mustImplement, jythonCode);
} else {
String moduleName = getNestedText(SodUtil.getElement(config, "module"));
String className = getNestedText(SodUtil.getElement(config, "class"));
PythonInterpreter interp = getPythonInterpreter();
interp.exec("from "+moduleName+" import "+className);
PyObject jyWaveformProcessClass = interp.get(className);
PyObject pyWaveformProcessObj = jyWaveformProcessClass.__call__( PyJavaType.wrapJavaObject(config));
return mustImplement.cast(pyWaveformProcessObj.__tojava__(mustImplement));
}
}