aardio 文档
aardio 范例: 导入模块
//导入模块
import console;
import py3;
var pyCode = /**
import urllib.request
def getHtml(url):
b = urllib.request.urlopen(url).read()
return b.decode("utf-8")
**/
//Python 模块请放在工程目录的 /py 目录下,
string.save("/py/myHttp.py",pyCode );//创建一个自定义模块文件
/*
默认在以下两个目录搜索 Python 模块:
这两个目录都会在生成 EXE 时复制到发布目录(即使 "\py" 目录没有添加到工程中)
"\py"
"~\lib\py3\.res\DLLs"
"\py" :
文件路径开始为单个斜杠(或反斜杠)表示应用程序根目录,
应用程序根目录在开发时指工程根目录(工程外单独启动代码则为文件所在目录),
发布后应用程序根目录就是指 EXE 所在的目录。
"~\lib\py3\.res\DLLs" :
aardio 规定文件路径开始为波浪线表示 EXE 所在的目录(开发时为 aardio.exe 所在目录)。
可以自己添加模块搜索路径,例如:
py3.appendPath("\py\site-packages\");
*/
//试试在 Python 中 import 上面保存的测试模块(当然也可以在 Python 代码中 import)
var myHttp = py3.import("myHttp");
//如果导入模块出错,打错错误信息。
console.log( py3.lasterr() );
var str = myHttp.getHtml("http://www.aardio.com" );
import console;
console.log( str );
console.pause()
/*
aardio 与 Python 的 import 语句基本用法类似,
都是用来导入模块,都要求文件名与模块路径与文件路径保持一致。
但 aardio 的 import 语句更简单,
Python 的 import 语句则有很多复杂的功能,例如:
from 模块名 import 函数名
from 模块名 import *
from hashlib import md5 as md5New
等等用法,并且可以任意添加修改搜索模块的路径。
aardio 需要在 import 过来的库中用 namespace 定义名字空间,而 Python 并不需要这么做,
Python 文件放到哪里模块名字就变成什么,所以经常会在 Python 代码中看到这句代码 if __name__ == "__main__":
如果一个库被直接执行 __name__ 的值就是 "__main__",否则就是当前导入的模块名字或者当前类的名字。
当然,复杂是有代价的,Python 的模块不但安装、部署比较麻烦,容易出现模块间的依赖与版本冲突,
在生成软件时也不容易做到按需引用、按需发布,但在 aardio 中我们可以用类似 py3.lib.numpy 这样的扩展库解决这一麻烦。
*/
Markdown 格式