前言
execjs是一款很好用的python调用js脚本的库,使得我们能够直接在python代码里编写js脚本并调用,一个常见的使用例如下:
import execjs
def syntax_check(code):
checker = execjs.compile("""
function syntax_check(code) {
try {
return true;
eval(code);
} catch (e) {
return !(e instanceof SyntaxError);
}
}
""")
return checker.call("syntax_check", code)
使用上面的代码即可完成对一个js脚本(即变量code)进行语法检查的功能。execjs之所以能实现这个功能,是因为其背后默认使用了node.js解释器,通过该解释器来执行js代码并返回结果。
问题
然而,node.js的功能有限,有时我们需要指定自己的js解释器,该怎么做呢?首先,execjs支持自定义的外部解释器来取代默认的node环境。比如,使用苹果的JavaScriptCore引擎作为解释器 ,可直接将上面的代码可以直接更新如下:
import execjs
from execjs.runtime_names import JavaScriptCore
def syntax_check(code):
jsc = execjs.get(JavaScriptCore)
checker = jsc.compile("""
function syntax_check(code) {
try {
return true;
eval(code);
} catch (e) {
return !(e instanceof SyntaxError);
}
}
""")
return checker.call("syntax_check", code)
然而,此时直接执行上述代码会抛出异常,即提示 JavaScriptCore在本机中找不到。这个是正常的,因为execjs对于外部解释器的路径是写死的, 找不到就报错了。
解决方案
通过阅读execjs库的源代码,很容易发现其写死外部解释器的地方:
execjs._external_runtime.py文件:
def jsc():
return ExternalRuntime(
name="JavaScriptCore",
command=["/System/Library/Frameworks/JavaScriptCore.framework/Versions/A/Resources/jsc"],
runner_source=_runner_sources.JavaScriptCore,
tempfile=True
)
直接修改源代码,将其修改为你本机的解释器路径即可,比如:
def jsc():
return ExternalRuntime(
name="JavaScriptCore",
command=["/root/ty/.jsvu/jsc"],
runner_source=_runner_sources.JavaScriptCore,
tempfile=True
)
保存后再执行,即可使用自己指定的JSC解释器。
补充
手动安装js引擎是一个费时费力的活,推荐使用谷歌官方的引擎安装工具来安装,地址:https://github.com/GoogleChromeLabs/jsvu
完结撒花~