火星链 火星链
Ctrl+D收藏火星链
首页 > OKB > 正文

LOAD:NEXT社区小课堂 | 第十三课:NEO Python编译器介绍(一)

作者:

时间:1900/1/1 0:00:00

NEXT社区|小课堂

由于近期NEXT社区加入很多新的小伙伴,有在校大学生,有对区块链感兴趣的传统企业从业者。为了更方便、更系统的让NEXT社区的伙伴们了解NEO的技术知识,因此我们开设了小课堂,每周3节,向大家普及NEO相关的知识要点!

NEXT社区小课堂|第十三课

NEOPython编译器介绍

neo-boa编译器介绍

neo-boa编译器可将Python文件编译为.avm格式,在NEO虚拟机中运行。NEO虚拟机可在NEO区块链上执行合约。

编译器支持Python语言子集。

1、目前功能

·?将Python语言子集编译成.avm格式,在NEO虚拟机上运行

·??适用于Python3.4与3.5

2、未来功能

·?编译更广泛的Python语言子集

·??适用于Python3.6

3、已支持的Python功能

下文为目前支持的Python功能一览。详细介绍请参见boa.tests.src目录中的案例

4、流控制

If、Else、Elif、While、Break、Methodcalls、Lamdbas、forxin

5、用于整数运算的算数运算符与相等运算符

ADD、SUB、MUL、DIV、ABS、LSHIFT、RSHIFT、AND、OR、XOR、MODULO、INVERT、GT、GTE、LT、LTE、EQ、NOTEQ

6、使用自定义内置功能进行列表创建。注意列表一经创建,其长度便不可更改。

fromboa.code.builtinsimportlist

#thisworks

x=list(length=10)

x=84

#thisalsoworks

x=

#thisdoesNOTwork

x=

x.append(1)

#支持列表操作

x=

y=x

#在可能的情况下,Python的某些__builtins__

数据:约6700万枚USDT从Kraken转至Bitfinex:金色财经报道,Whale Alert监测数据显示,北京时间09:23:23,69995990枚USDT从Kraken转至Bitfinex。[2022/11/24 8:02:39]

#已经根据NEO虚拟机的特点以自定义的方式实现

fromboa.code.builtinsimportrange

xrange=range(1,30)

#thisalsoworks

foriinrange(2,21):

i=i1

安装

1、使用pip

pipinstallneo-boa

2、手动安装

克隆存储库,进入项目目录后创建Python3虚拟环境,并通过以下指令激活。

python3?-mvenvvenvsourcevenv/bin/activate

或单独安装Python3.5

virtualenv?-p?/usr/local/bin/python3.5venvsourcevenv/bin/activate

或单独安装Python3.5

virtualenv?-p?/usr/local/bin/python3.5venvsourcevenv/bin/activate

接着,通过以下指令安装需求

pipinstall?-rrequirements.txt

3、基本用途

编译器使用指南如下

fromboa.compiler?import?CompilerCompiler.load_and_save('path/to/your/file.py')

4、许可证

·开源MIT?

·主作者为localhuman

5、boa.compiler.Compiler

下文将介绍Compiler的具体实现细则。

6、classboa.compiler.Compiler

主编译器接口类

通过下列程序加载python文件,编译为.avm格式,并与python文件存储在一个地方。

Nexo管理合伙人:2022年真正让我兴奋的是元宇宙这个概念:金色财经报道,加密货币银行Nexo的管理合伙人Antoni Trenchev表示,“2022年对比特币和其他加密货币影响最大的是央行政策,资金成本料将保持低位,这对加密货币产生巨大影响,美联储不敢让股市暴跌10%-20%”。Trenchev预计2022年市场将大幅波动,但到6月底比特币有望达到10万美元。他认为,Solana和Avalanche等代币不会像2021年那样出现指数级增长,“这些新贵将面临与以太坊和其他更老加密货币一样的挑战”。

“2022年真正让我兴奋的是元宇宙这个概念,”他写道。 “元宇宙的诞生和使用既美又混乱,但未来它有很大的潜力。未来一年最主要的几个主题包括:元宇宙,基础设施建设,NFT”。(新浪财经)[2022/1/4 8:22:31]

fromboa.compilerimportCompilerCompiler.load_and_save(‘path/to/your/file.py’)#returnthecompilerobjectforinspectioncompiler=Compiler.load(‘path/to/your/file.py’)#retrievethedefaultmoduleforinpectiondefault_module=compiler.default#retreivethedefault/entrymethodforthesmartcontractentry_method=default_module.main

7、defaule

取回默认或“入口”模块。

返回值:默认反回值为boa.code.Module对象,异常时无返回值

8、staticinstance()

取回当前编译器对象的实例,否则创建一个实例

返回值:编译器对象的单个实例

9、staticload(path)

调用load来加载需编译但无需写为.avm格式的Python文件

参数:path–Python文件的编译路径

返回值:编译器实例

用途:通过下述程序返回编译器对象进行检查

fromboa.compiler?import?Compilercompiler?=?Compiler.load(‘path/to/your/file.py’)

Bitfinex上线Terra(LUNA):Bitfinex官方公告显示即将上市Terra(LUNA),目前已经开放存款。LUNA将从北京时间4月16日17:00开放LUNA / USD和LUNA / USDT两个交易对。[2021/4/14 20:19:38]

10、staticload_and_save(path,output_path=None)

调用load_and_save来加载需编译为.avm格式的Python文件,并保存结果。

默认情况下,最终生成的.avm文件将与源文件存储在一个地方。

参数:

·path——Python文件的编译路径

·output_path——已编译的.avm文件的可选保存路径

返回值:返回编译器实例

用途:通过下述代码返回编译器对象进行检查

fromboa.compilerimportCompiler

Compiler.load_and_save(‘path/to/your/file.py’)

11、write()

返回值:已编译的Python程序的字节串

12、staticwrite_file(data,path)

通过指定路径将输出数据存储至文件系统

参数:

·data——待写入磁盘的数据字节串

·path——文件写入路径

13、boa.code.module.Module

下文将介绍Module的具体实现细则。

14、classboa.code.module.Module(path,module_name=”,is_sys_module=False,items_to_import=None)

模块是包含代码对象的顶层组件。例如,在path/to/my/file.py的编译过程中,file.py中包含的项目即为模块。一个可执行项可包含多个模块。上述案例中的“默认”或“入口”模块即为file.py。

调用Compiler.load_and_save(‘path/to/file.py’)时会专门为file.py创建一个模块。若file.py导入了其他任何功能,那些模块也会被添加至可执行项中,并置于Module.loaded_modules属性中。

声音 | Bitfinex CTO:50亿USDT是从Omni到TronTether切换时的数据错误标记:对于Tether Treasury增发50亿USDT一事,Bitfinex兼Tether首席科技官Paolo Ardoino已经在推特上做出回应,他表示这是一次从Omni到TronTether切换时的数据标记出现了一个问题。Paolo Ardoino称,我们必须在多个链上使用不同的工具链,有时会出现问题。无论如何,我们正在努力防止未来再发生这种情况。[2019/7/14]

在模块被当做方法处理,方法被当做基本块处理,基本块被处理为标记后,主模块或default模块的write()方法即被调用,将可执行项写为字节串,返回磁盘并存储。

如果您想检查模块内容,可使用Compiler.load(‘path/to/file.py’),该功能将返回一个编译器实例。获取该实例后,您便可以访问编译器的default模块,从而访问该默认模块中装入的其他模块。

各模块均包含byteplay3对象bp的引用,该对象包含可在Python解释器中显示的指令集。

您可对具备bp属性的任意对象调用print(module.bp.code),结果将输出一段Python解释器代码。

fromboa.compilerimportCompiler

module=Compiler.load

(‘./boa/tests/src/AddTest1.py’).default

print(module.bp.code)

LOAD_CONST

LOAD_CONST‘Main’

MAKE_FUNCTION0

STORE_NAMEMain

LOAD_CONSTNone

RETURN_VALUE

对可执行项进行处理与标记化后,便会生成虚拟机标记集,虚拟机标记虽与byteplay3标记相类似,但仍存在显著区别。这些标记均包含在该模块的all_vm_tokens属性中。

您可调用module.to_s()来查看该程序,因为该程序已根据NEO虚拟机的特点进行了标记化。

>>>module.to_s()

LOAD_FAST?

动态 | 1000万枚USDT转入Bitfinex交易所:据合约帝链上数据监测显示,北京时间6月17日20:40,比特币链上出现一笔1000万枚USDT的大额转账交易,转入账户为Bitfinex交易所。据悉,Bitfinex交易所24小时USDT流入量144万,流出量为686万,本周以来持续为净流出状态。[2019/6/17]

LOAD_CONST

BINARY_MULTIPL??

STORE_FAST?

LOAD_FAST?

LOAD_CONST?

BINARY_ADD????

LOAD_FAST

LOAD_CONST

BINARY_TRUE_DIVIDE

STORE_FAST?

LOAD_FAST?

LOAD_CONST?

BINARY_SUBTRACT

STORE_FAST

b''

LOAD_FAST

LOAD_FAST

BINARY_ADD????

LOAD_FAST?

BINARY_ADD

LOAD_FAST?

BINARY_ADD

NOP

15、add_method(method)

在模块中添加方法如下:

Parameters:?method(boa.code.method.Method)——模块中待添加的方法对象

返回值:显示是否已添加该方法

返回值类型:布尔值

16、build()

将bp.code对象拆分成行,并合并多行,生成不同的项目。

17、link_methods()

关联各方法地址

18、main

返回该模块的默认方法

返回值:该模块的默认方法

返回值类型:boa.code.method.Method

19、method_by_name(method_name)

在模块的methods列表中查找方法名称:parammethod_name:

待查找的方法名称:typemethod_name:str

返回值:方法

返回值类型:boa.code.method.Method

20、module_path

返回该模块的文件路径

返回值:模块路径

返回值类型:str

21、orderered_methods

方法序列表

返回值:该模块中的方法序列表

返回值类型:列表

22、process_action(lineset)

处理模块中的动作,样本如下,其目的类似于创建下列事件:

fromboa.blockchain.vm.Neo.ActionimportRegisterAction

#Registertheaction.

onRefund=RegisterAction(‘refund’,’to_address’,’amount’)

#Dispatchanaction.

onRefund(my_address,100)

参数:lineset(list)–包含应用程序调用注册功能的行集

23、process_import(import_item)

处理该模块中的导入语句

Parameters:?import_item(boa.code.items.Importsubclass)–

24、process_method(lineset)

处理包含byteplay3代码对象的行集

参数:lineset(list)–需处理与添加的行集

25、process_smart_contract_app_registration(lineset)?

在智能合约中调用另一个智能合约时处理智能合约应用程序注册事宜:

fromboa.blockchain.vm.Neo.AppimportRegisterAppCall

#registerthecontract

otherContract=RegisterAppCall(‘contract_hash’,’param1′,’param2′)

#callthecontract

result=otherContract(a,b)

参数:lineset(list)–包含应用程序调用注册功能的行集

26、split_lines()

将模块中的行集拆分成可编译的对象集

27、to_s()

该方法的目的在于以可读/标记化的格式打印可执行项的输出值,样本如下:

>>>fromboa.compilerimportCompiler

>>>module=Compiler.

load('./boa/tests/src/LambdaTest.py').default

>>>module.write()

>>>module.to_s()

LOAD_CONST

STORE_FAST

LOAD_FAST

CALL_FUNCTION?Main..

q_1

STORE_FAST

b''

m??

NOP?

RETURN_VALUE??

b''?

LOAD_FAST?x?

LOAD_CONST?

BINARY_ADD??

NOP????

RETURN_VALUE?

28、tokenize()

将boa.code.pytoken.PyToken对象集转化为boa.code.vmtoken.VMToken对象。

29、total_lines

获取该方法的总行数

返回值:总行数

返回值类型:int

30、total_module_variables

获取局部变量总数

返回值:该模块中的变量总数

返回值类型:int

31、vm_tokens

返回该方法中的虚拟机标记列表

返回值:该方法中的虚拟机标记列表

返回值类型:列表

32、write()

将标记器当前的状态写为字节串

返回值:当前标记器的字节串

返回值类型:字节

原文链接:https://github.com/localhuman/neo-python

往期精彩内容

NEXT社区小课堂|第五课:NEO-共识算法dBFT源码解析

NEXT社区小课堂|第八课:如果往错误的NEO地址转账会发生什么

NEXT社区小课堂|第十课:如何正确理解NEO平台上的GAS

NEXT社区小课堂|第十一课:NEO中数字的表达和运算

??

联系我们?

微博:https://weibo.com/u/6724929880

官网:https://neonext.club/

QQ群:612334080

电报:https://t.me/neonextop

twitter:https://twitter.com/NE0NEXT

关注NEONEXT官方公众号

获取更多一手社区资讯

标签:COMLOADLOAMPICOMOS价格KIRBYRELOADED币FLOATEMPIRE价格

OKB热门资讯
ETH:6月4日行情分析:比特币跌破8000,下一步动作选择?

秦川说币前言:早间大盘又是一轮大幅度的急跌,整体振幅超过百分之5.6,振幅空间逐步放大,向下试探筑底的动作开始出现。这一波急跌场内2小时BTC资金净流出超1.47亿美元.

1900/1/1 0:00:00
加密货币:SEC主席:不能用同“股票和债券一样的方式”去监管加密货币

作者LiangCHE6月6日,美国证券交易委员会主席JayClayton接受了CNBC的“SquawkBox”节目的采访。他在采访中提到了该监管机构对比特币等加密货币的最新看法.

1900/1/1 0:00:00
BTC:6.5晚间行情:主流币等待明确信号 山寨币开启赚钱效应

文章系金色财经专栏作者供稿,发表言论仅代表其个人观点,仅供学习交流!金色盘面不会主动提供任何交易指导,亦不会收取任何费用指导交易,请读者仔细甄别,谨防上当.

1900/1/1 0:00:00
BCH:人物 算力之王 吴忌寒重启人生

前段时间,比特大陆公开内部信,证实了吴忌寒与詹克团已经同时卸任比特大陆CEO之位。前几天,我们一起回顾了詹克团的辉煌过往,今天我们将目光移至他曾经的“黄金搭档”吴忌寒身上.

1900/1/1 0:00:00
门罗币:研究报告:比特币在Reddit上讨论最多,平均每天3600条评论

据Coindesk报道,美国能源部的一个实验室一直在研究三种流行加密货币在Reddit聊天中的表现.

1900/1/1 0:00:00
FME:火星一线 | 张健:FMex是FCoin开发团队筹备已久的战略型产品

火星财经APP一线报道,6月5日晚,FT生态下的合约交易平台FMex首次举办线上发布会,FCoin创始人张健对FMex平台的合约业务、收入分配、社区化治理、可持续挖矿机制等问题进行一一解答.

1900/1/1 0:00:00