函数

  • 函数的定义关键字:def

  • 使用global语句可以清楚地表明变量是在外面的块定义的

  • 示例:(函数运行完毕后x的值是2)

  1. #!/usr/bin/python
  2. # Filename: func_global.py
  3. def func():
  4. global x
  5. print 'x is', x
  6. x = 2
  7. print 'Changed local x to', x
  8. x = 50
  9. func()
  10. print 'Value of x is', x
  • 可以给形参加上默认值,默认参数是不可变的,而且只有在形参表末尾的那些参数可以有默认参数值,即你不能在声明函数形参的时候,先声明有默认值的形参而后声明没有默认

    值的形参。这是因为赋给形参的值是根据位置而赋值的。例如,def func(a, b=5)是有效的,但是def func(a=5, b)是无效的。

  • 示例:

  1. #!/usr/bin/python
  2. # Filename: func_default.py
  3. def say(message, times = 1):
  4. print message * times
  5. say('Hello')
  6. say('World', 5)
  1. Hello
  2. WorldWorldWorldWorldWorld
  • 关键参数,很有意思,可以根据指定的参数名字赋值,而不必每次都要按位置赋值

  • 示例:

  1. #!/usr/bin/python
  2. # Filename: func_key.py
  3. def func(a, b=5, c=10):
  4. print 'a is', a, 'and b is', b, 'and c is', c
  5. func(3, 7)
  6. func(25, c=24)
  7. func(c=50, a=100)

运行结果:

  1. $ python func_key.py
  2. a is 3 and b is 7 and c is 10
  3. a is 25 and b is 5 and c is 24
  4. a is 100 and b is 5 and c is 50
  • pass语句在Python中表示一个空的语句块。就像在java/c++里面的;

  • 除非你提供你自己的return语句,每个函数都在结尾暗含有return None语句

  • 文档字符串DocStrings,它所做的只是抓取函数的__doc__属性,然后整洁地展示给你

  1. #!/usr/bin/python
  2. # Filename: func_doc.py
  3. def printMax(x, y):
  4. '''Prints the maximum of two numbers.
  5. The two values must be integers.'''
  6. x = int(x) # convert to integers, if possible
  7. y = int(y)
  8. if x > y:
  9. print x, 'is maximum'
  10. else:
  11. print y, 'is maximum'
  12. printMax(3, 5)
  13. print printMax.__doc__

python学习之路-第三天-函数的更多相关文章

  1. 大数据萌新的Python学习之路(三)

    笔记内容:  一.集合及其运算 在之列表中我们可以存储数据,并且对数据进行各种各样的操作.但是如果我们想要对数据进行去重时是十分麻烦的,需要使用循环,要建立新的列表,还要 进行对比,十分的麻烦,还消耗 ...

  2. python学习之路-4 内置函数和装饰器

    本篇涉及内容 内置函数 装饰器 内置函数 callable()   判断对象是否可以被调用,返回一个布尔值 1 2 3 4 5 6 7 8 9 10 11 num = 10 print(callabl ...

  3. python学习之路 第三天

    1.set集合:去掉重复字段 set.difference()找出不同并创建一个新的集合,不改变原来集合: set.difference_update() 改变原来集合,剔除掉括号内容: set.di ...

  4. Python学习之路 (三)爬虫(二)

    通用爬虫和聚焦爬虫 根据使用场景,网络爬虫可分为 通用爬虫 和 聚焦爬虫 两种. 通用爬虫 通用网络爬虫 是 捜索引擎抓取系统(Baidu.Google.Yahoo等)的重要组成部分.主要目的是将互联 ...

  5. Python学习之路-Day2-Python基础3

    Python学习之路第三天 学习内容: 1.文件操作 2.字符转编码操作 3.函数介绍 4.递归 5.函数式编程 1.文件操作 打印到屏幕 最简单的输出方法是用print语句,你可以给它传递零个或多个 ...

  6. Python学习之路-Day2-Python基础2

    Python学习之路第二天 学习内容: 1.模块初识 2.pyc是什么 3.python数据类型 4.数据运算 5.bytes/str之别 6.列表 7.元组 8.字典 9.字符串常用操作 1.模块初 ...

  7. Python学习之路【第一篇】-Python简介和基础入门

    1.Python简介 1.1 Python是什么 相信混迹IT界的很多朋友都知道,Python是近年来最火的一个热点,没有之一.从性质上来讲它和我们熟知的C.java.php等没有什么本质的区别,也是 ...

  8. python学习之路------你想要的都在这里了

    python学习之路------你想要的都在这里了 (根据自己的学习进度后期不断更新哟!!!) 一.python基础 1.python基础--python基本知识.七大数据类型等 2.python基础 ...

  9. python学习之路-day2-pyth基础2

    一.        模块初识 Python的强大之处在于他有非常丰富和强大的标准库和第三方库,第三方库存放位置:site-packages sys模块简介 导入模块 import sys 3 sys模 ...

随机推荐

  1. nutch solr

    创建solr数据目录 创建目录solrData,拷贝solr-4.10.2/example/solr到solrData下     修改配置文件中数据目录路径 修改 solrData/solr/coll ...

  2. ubuntu qt5 error: Unknown module(s) in QT: webkitwidgets解决办法

    question: project-error-unknown-modules-in-qt-webkitwidgets-webkit os: ubuntu16.04 LTS-32bit qmake v ...

  3. hdu6053 TrickGCD 容斥原理

    /** 题目:hdu6053 TrickGCD 链接:http://acm.hdu.edu.cn/showproblem.php?pid=6053 题意:You are given an array ...

  4. MapReduce实战(三)分区的实现

    需求: 在实战(一)的基础 上,实现自定义分组机制.例如根据手机号的不同,分成不同的省份,然后在不同的reduce上面跑,最后生成的结果分别存在不同的文件中. 对流量原始日志进行流量统计,将不同省份的 ...

  5. easyui 扩展 之 Tree的simpleData加载

    实例化.这里增加了三个属性,可以指定idFiled,textFiled和parentField.所以这里的simpleData可以不严格转换成tree的数据格式. $(function(){ $('# ...

  6. FireBug与FirePHP

    a.FireBug,平时用的比较多.就是在客户端调试代码.如:hTML ,CSS,JS等 b.FireBug安装较容易. b-1,打开火狐浏览器 b-2,打开“附加组件” b-3.搜索“firebug ...

  7. 理解java的 多态

    http://www.cnblogs.com/chenssy/p/3372798.html

  8. CentOS中Apache虚拟主机(virtualHost)设置在/home目录下的若干问题

    在Ubuntu中安装LAMP是非常简单的意见事情.但是在CentOS中却遇到了很多问题. 首先是CentOS中必须手动配置iptables,把80端口开放出来,不然,是访问不到的,开放80端口在/et ...

  9. 【BZOJ2927】[Poi1999]多边形之战 博弈

    [BZOJ2927][Poi1999]多边形之战 Description 多边形之战是一个双人游戏.游戏在一个有n个顶点的凸多边形上进行,这个凸多边形的n-3条对角线将多边形分成n-2个三角形,这n- ...

  10. [LintCode] 二叉树的中序遍历

    The recursive solution is trivial and I omit it here. Iterative Solution using Stack (O(n) time and  ...