python函数结构_PYTHON 之结构体,全局变量,函数参数,lambda编程 等

PYTHON 之结构体,全局变量,函数参数,lambda编程 ,generator(yield)使用以及如何自己构建switch结构

***********************

pass

pass可以模拟struct结构

class Data

pass

d = Data()

d.a = 2

d.b = 4

print d.a

print d.b

***********************

子函数传参数的有趣的地方

def cheeseshop(kind, *arguments, **keywords):

print "-- Do you have any", kind, "?"

print "-- I'm sorry, we're all out of", kind

for arg in arguments: print arg #一个星号的arguments表示传入n元组tuple,可以想像成list或者数组

print "-" * 40

keys = keywords.keys()#两个星号的表示传入的是一个字典结构

keys.sort()

for kw in keys: print kw, ":", keywords[kw]

cheeseshop("Limburger", "It's very runny, sir.", "It's really very, VERY runny, sir.", shopkeeper='Michael Palin', client="John Cleese", sketch="Cheese Shop Sketch")

除了第一个参数被当做kind的值,剩下的将被构成一个tuple(和list相似,理解成数组吧),这些被当成整体传入函数cheeseshop,剩下的形如k=v的则全部被构建成一个词典dictionary 对象,然后传进入。

感觉这样的主要好处是定义函数cheeseshop的时候需要写的参数少了,同样类型的使用argument就好了,但是如果给别人调用的话,这样写恐怕非常不好。

当然,如果你写成

def testArg(*argument,*argument):

for a in argument: print a

那是不对的, 最多只能有一个参数是*的形式

***********************

使用全局变量

比如在外面定义了a,则函数内部如果想使用全局变量a,加上

global a

***********************

yield的用法

yield 是generator的关键词,看看generator

http://www.python.org/dev/peps/pep-0255/ 说明了采用generator的原因,并给出了一些restriction,最后使用binary tree作为例子

http://www.ibm.com/developerworks/library/l-pycon.html?S_TACT=105AGX52&S_CMP=cn-a-x

A generator is a function that remembers the point in the function body where it last returned. Calling a generator function a second (or nth) time jumps into the middle of the function, with all local variables intact from the last invocation.

yield 产生一个generator,这个generator有两个好处:

1)记录了产生generator的函数的内部状态,也就是数据的值

2)记录了该函数正在执行的语句,下一次调用将从上次执行yield语句的下一条开始执行。

***********************

switch

python没switch,但是有多种方法来实现switch,看看下面的例子把

#!/usr/local/bin/python

# coding: UTF-8

#first case

a = 2

def print1():

print 1

def print2():

print 2

def print3():

print 3

def print1():

print 'default'

#使用单条语句,然后使用exec函数执行

valuesStatement = {

1: 'print 1',

2: 'print 2',

3: 'print 3'

}

#使用函数,即获得了函数句柄,然后就可以直接调用

valuesFunc = {

1: print1,

2: print2,

3: print3

}

exec(valuesStatement.get(1,'print 2'))

valuesFunc.get(1,'default')()#注意,这里括号的位置,其实就是相当于首先取得函数指针,然后调用,如果你直接

print valuesFunc.get(1,'default') #的话,你就会看到函数的地址

#second case

#使用lambda, definition

#http://en.wikipedia.org/wiki/Lambda_calculus

#http://www.mathstat.dal.ca/~selinger/papers/lambdanotes.pdf,看看这篇文章可以更好的理解lambda,我看了Church理论证明之前的部分,理解了lambda怎么回事,但是lambda和函数编程之间的关系确解释不清楚,感觉函数编程并不依赖与lambda

#lumbda 如何使用

def make_incrementor(n):

return lambda x: x + n

f = make_incrementor(4) #这里相当于我们获得了一个函数

print f(3) #call

#那么使用lumbda实现switch吧,类似前面所属使用statement的方式,只是不需要使用exec了

result = {

'a': lambda x: x * 5,

'b': lambda x: x + 7,

'c': lambda x: x - 2

}

f = result['a']

print f(3)

#third case

#使用类

#This class provides the functionality we want. You only need to look at

# this if you want to know how this works. It only needs to be defined

# once, no need to muck around with its internals.

class switch(object):

def __init__(self, value):

self.value = value

self.fall = False

def __iter__(self ):

"""Return the match method once, then stop"""

yield self.match

raise StopIteration

def match(self, *args):

"""Indicate whether or not to enter a case suite"""

if self.fall or not args:#为Ture或者默认,默认是没有参数的

return True

elif self.value in args: # changed for v1.5, see below

self.fall = True

return True

else:

return False

# The following example is pretty much the exact use-case of a dictionary,

# but is included for its simplicity. Note that you can include statements

# in each suite.

v='ten'

for case in switch(v):#因为重写了 def __iter__(self):,而该函数返回match函数,从而可以传入参数并判断是否相等

if case('one'):#这里和普通case不同,前面多了个if,作者只是在形式上模拟了switch-case,实际用的是if

print 1

break

if case('two'):

print 2

break

if case('ten'):

print 10

break

if case('eleven'):

print 11

break

if case(): # default, could also just omit condition or 'if True'

print "something else!"

# No need to break here, it'll stop anyway

#无需多解释了,作者巧妙的利用了python的for功能来让iter返回函数指针,进而接受参数确定是否执行之。

#要注意,case前面必须有if,否则,就不奏效拉,因为作者就是用了mathc的返回值

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/336293.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【音视频安卓开发 (六)】Android GLSurfaceView播放视频

GLSurfaceView渲染RGB的数据,利用双缓冲空间机制。取出缓冲地址,将要渲染的数据copy到缓冲地址. 获取Surface Java部分: SurfaceView控件设置到界面中显示 SurfaceView定义一个类来实现 package com.example.hello;import android.content.Context; import android…

什么是openstack_您在OpenStack Summit 2016上错过了什么

什么是openstack今年,我第一次参加了4月25日至29日在德克萨斯州奥斯汀举行的OpenStack峰会。 今天结束了,我要回家了,我想回顾一下,从我的角度分享你错过的事情。 作为以应用程序开发人员为重点的技术传播者,转移到包…

python链表实现栈_使用python实现数组、链表、队列、栈

引言 什么是数据结构? 数据结构是指相互之间存在着一种或多种关系的数据元素的集合和该集合中数据元素之间的关系组成。 简单来说,数据结构就是设计数据以何种方式组织并存储在计算机中。 比如:列表,集合和字典等都是数据结构 N.W…

笛卡尔乘积c语言代码,c# – 高效笛卡尔乘积算法

有人可以向我证明比目前使用的笛卡儿乘积算法更有效(假设有一个)。我已经看了周围的SO和谷歌,但看不到任何明显的东西,所以我可能会缺少一些东西。foreach (int i in is) {foreach (int j in js) {//Pair i and j}}这是我在代码中做的非常简化的版本。两…

【音视频安卓开发 (七)】安卓视频播放窗口去掉标题栏、全屏、横屏

java中的MainActivity初始化部分设置这些操作 //去掉标题栏supportRequestWindowFeature( Window.FEATURE_NO_TITLE);//全屏,隐藏状态getWindow().setFlags( WindowManager.LayoutParams.FLAG_FULLSCREEN ,WindowManager.LayoutParams.FLAG_FULLSCREEN);//屏幕为横屏…

drools6.5_Drools 6.4.0.Final提供

drools6.5最新和最出色的Drools 6.4.0.Final版本现已可供下载。 这是我们先前构建的增量版本,对核心引擎和Web工作台进行了一些改进。 您可以在此处找到更多详细信息,下载和文档: Drools网站 资料下载 文献资料 发行说明 请阅读下面的…

python 统计组合用什么库_Python机器学习需要用到的库

www.oldboyedu.com 老男孩 IT 教育,只培养技术精英 Python 机器学习需要用到的库 Python 是一种面向对象的解释型计算机程序设计语言,具有丰富和强大的 库,再加上其简单、易学、速度快、开源免费、可移植性、可扩展性以及面向对 象的特点&…

c语言编程数学黑洞,一个数学黑洞——6174

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼/*问题描述:从0-9中任意选取4个不完全相同的数比如,不能是5 5 5 5,可以是1 2 2 2用这4个数排列出最大的数,2221,最小的数1222最大减最小:2221-12220999用0 9 9…

【音视频安卓开发 (八)】OpenSLES播放音频步骤和接口讲解

OpenSLES是安卓内部的音频播放和录音 初始化引擎 创建输出设备 配置PCM格式信息 初始化播放器 播放和缓冲队列 本文开源项目下载

kata_FizzBu​​zz Kata与Java流

kata在柔道练习仅几周之后,我的儿子感到无聊。 他抱怨说自己没有学任何东西,因为他一遍又一遍地做着同样的事情。 混淆学习和做新事物的不仅是幼儿。 例如,有多少软件开发人员通过执行kata或参加dojos来进行刻意练习的麻烦? 重复…

python中if语句的实例_对python中if语句的真假判断实例详解

说明 在python中,if作为条件语句,当if后面的条件参数为真时,则执行后面的语句块,反之跳过,为了深入理解if语句,我们需要知道if语句的真假判断方式。 示例 在python交互器中,经过测试发现以下条件…

ds18b20c语言显示小数位,DS18B20多点测温(读序列,匹配序列,51单片机C程序,1602显示)...

DS18B20多点测温(读序列,匹配序列,51 C程序,1602显示)程序一:单个读序列号。程序二,匹配并且读两个DS18B20,当然,读多个与读两个基本原理一样,只要加上其序列号等即可。本程序所有显…

【WebRTC---入门篇】(五)Web服务器原理与Nodejs搭建

Web服务器工作原理 Nodejs工作原理 首先自己开发的APPLICATION(自己开发的JS程序)输出给V8引擎,解析后的二进制文件调用NODE API,然后调用LIBUV事件处理库(插入到事件队列,在队列中不断循环处理事件)。 JavaScript解析 V8引擎先收到JS程序,解析生成JS语法树,通过解析器…

代理模式和动态代理模式_代理模式介绍

代理模式和动态代理模式代表:被选中或当选为他人投票或代理的人– Merriam-Webster 。 委托模式:在软件工程中,委托模式是面向对象编程中的一种设计模式,其中,一个对象而不是执行其陈述的任务之一,而是将该…

【WebRTC---入门篇】(六)JavaScript基础

变量与类型 var与let的区别,var局部变量;let全局变量 函数

javaio流层次结构_流的多层次分组

javaio流层次结构1.简介 使用Java 8流,可以很容易地根据不同的标准对对象集合进行分组。 在这篇文章中,我们将看到如何从简单的单级分组到更复杂的,涉及多个级分组的分组。 我们将使用两个类来表示我们要分组的对象:人和宠物。 …

【开源项目----Android OPenGLES渲染YUV视频文件】

【开源项目----Android OPenGLES渲染YUV视频文件】 OpenGLES对YUV渲染相关文章参考

大型程序是如何开发的_大型小程序如何研发提效

作者:王梦君微信公众号:滴滴顺风车技术出处:https://mp.weixin.qq.com/s/M1VArJ_ORY-eXSKzD6ysQw导读:自2016年小程序诞生以来,小程序以其“用完即走”的设计理念,以及简单易上手的开发模式,吸引了大批的小程序使用者以及开发者&a…

c 语言栈,C语言栈

C语言实现简单的栈结构今天看到一个问题是要交换两个变量的值并且不能使用中间变量,首先想到的方法就是用数学的方法:int a 10,b 12;a a b; // 求和b a - b; // 和减去b得到的是a的值a a - b; // 和减去a(此时的b是最初a的值)得到b 的值这种方法很…

【WebRTC---入门篇】(七)MediaStream

MediaStream方法 MediaStream.addTrack( ) 功能:向流媒体中加入不同的轨 MediaStream.removeTrack( ) 功能:从流媒体中移除不同的轨 MediaStream.getVideoTracks( ) 功能:从流媒体中取出所有的视频轨 MediaStream.getAudioTracks( …