ironpython使用dictionary_第一个IronPython程序(之一)

本文介绍了一个IronPython程序,展示了如何定义和使用函数,如`add`、`factorial`和`BuildConnectionString`。程序输出了连接字符串、字符串相加的结果以及100的阶乘。IronPython不需指定函数返回类型或参数类型,通过docstring提供函数说明。

这是一个完整的, 可执行的 IronPython程序。

它可能对您来说根本无法理解。别着急, 我们将逐行的进行剖析。不过首先把代码通读一遍, 看一看是否有些可以理解的内容。

例2.1 first.py 这个程序来自IronPython的例子,添加了一点内容

def add(a, b):

"add(a, b) -> returns a + b"

return a + b

def factorial(n):

"factorial(n) -> returns factorial of n"

if n <= 1: return 1

return n * factorial(n-1)

def BuildConnectionString(params):

"""Build a connection string from a dictionary of parameters.

Returns string."""

return "".join(["%s=%s" % (k, v) for k, v in params.items()])

hi = "Hello from IronPython!"

if __name__ == "__main__":

myParams = {"server":"shanyou.zhang", \

"database":"pubs", \

"uid":"sa", \

"pwd":"secret" \

}

print BuildConnectionString(myParams)

print add(hi,"Zhangshanyou")

print factorial(100)

现在运行一下这个程序, 看一看结果是什么。在命令行中切换到Tutorial目录,执行命令ipy first.py

first.py输出的结果如下:

server=shanyou.zhang;database=pubs;uid=sa;pwd=secret

Hello from IronPython!Zhangshanyou

93326215443944152681699238856266700490715968264381621468592963895217599993229915

608941463976156518286253697920827223758251185210916864000000000000000000000000

与其它大多数语言一样IronPython 有函数, 但是它没有像 C++ 一样的独立的头文件;或者像 Pascal 一样的分离的 interface/implementation 段。 一旦需要函数时, 像下面这样声明即可:def BuildConnectionString(params):首先, 函数声明以关键字 def 开始, 接着为函数名, 再往后为参数, 参数放在小括号里。 多个参数之间 (这里没有演示) 用逗号分隔。

其次, 函数没有定义返回的数据类型。 IronPython 不需要提定返回值的数据类型;甚至不需要指定是否有返回值。实际上, 每个 IronPython 函数都返回一个值;如果函数执行过 return 语句, 它将返回指定的值, 否则将返回 None ( IronPython 的空值) 。

最后需要指出的是, 在 IronPython 中参数, params 不需要指定数据类型。 IronPython 会判定一个变量是什么类型, 并在内部将其记录下来。

可以通过给出一个 doc string (文档字符串) 文档化一个 IronPython 函数。

例 2.2. 定义 BuildConnectionString 和factorial函数的 doc string

def factorial(n):

"factorial(n) -> returns factorial of n"def buildConnectionString(params):

"""Build a connection string from a dictionary of parameters.

Returns string."""

单个引号表示一个单行字符串,三重引号表示一个多行字符串。在开始与结束引号间的所有东西都被视为单个字符串的一部分, 包括硬回车和其它的引号字符。您可以在任何地方使用它们, 但是您可能会发现它们经常被用于定义 doc string 的情况。

三重引号也是一种定义既包含单引号又包含双引号的字符串的简单方法。

在三重引号中的任何东西都是这个函数的 doc string, 它们用来说明函数可以做什么。 如果存在 doc string, 它必须是一个函数要定义的第一个内容( 也就是说, 在冒号后面的第一个内容 )。 在技术上不要求给出函数的 doc string, 但是您应该这样做。我相信在您上过的每一种编程课上都听到过这一点, 但是 IronPython 带给您一些额外的动机: doc string 在运行时可作为函数的属性。

基于可靠性评估序贯蒙特卡洛模拟法的配电网可靠性评估研究(Matlab代码实现)内容概要:本文围绕“基于可靠性评估序贯蒙特卡洛模拟法的配电网可靠性评估研究”,介绍了利用Matlab代码实现配电网可靠性的仿真分析方法。重点采用序贯蒙特卡洛模拟法对配电网进行长时间段的状态抽样与统计,通过模拟系统元件的故障与修复过程,评估配电网的关键可靠性指标,如系统停电频率、停电持续时间、负荷点可靠性等。该方法能够有效处理复杂网络结构与设备时序特性,提升评估精度,适用于含分布式电源、电动汽车等新型负荷接入的现代配电网。文中提供了完整的Matlab实现代码与案例分析,便于复现和扩展应用。; 适合人群:具备电力系统基础知识和Matlab编程能力的高校研究生、科研人员及电力行业技术人员,尤其适合从事配电网规划、运行与可靠性分析相关工作的人员; 使用场景及目标:①掌握序贯蒙特卡洛模拟法在电力系统可靠性评估中的基本原理与实现流程;②学习如何通过Matlab构建配电网仿真模型并进行状态转移模拟;③应用于含新能源接入的复杂配电网可靠性定量评估与优化设计; 阅读建议:建议结合文中提供的Matlab代码逐段调试运行,理解状态抽样、故障判断、修复逻辑及指标统计的具体实现方式,同时可扩展至不同网络结构或加入更多不确定性因素进行深化研究。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值