一、为什么要使用函数?

   1.避免代码重用

   2.提高代码的可读性

二、函数的定义与调用

1def  函数名(参数1,参数2):

    ''' 函数注释'''

    print('函数体')

    return 返回值

  定义:def关键字开头,空格之后接函数名和圆括号,最后还要加一个冒号。

    def是固定的,不能变。

  函数名:函数名是包含字母,数字,下划线的任意组合,但是不能以数字开头。虽然函数名可以随便取名,但是一般尽量定义成可以表示函数功能的。

2.函数的调用

     返回值=函数名(参数1,参数2)#记得函数名后面加括号

 函数和方法的区别

1、函数要手动传self,方法不用传

2、如果是一个函数,用类名去调用,如果是一个额方法,用对象去调用

举例说明:

  1. class Foo(object):
  2. def __init__(self):
  3. self.name="haiyan"
  4. def func(self):
  5. print(self.name)
  6.  
  7. obj = Foo()
  8. obj.func()
  9. Foo.func(obj)

判断函数和方法的方式

  1. from types import FunctionType,MethodType
  2. obj = Foo()
  3. print(isinstance(obj.func,FunctionType)) #False
  4. print(isinstance(obj.func,MethodType)) #True #说明这是一个方法
  5.  
  6. print(isinstance(Foo.func,FunctionType)) #True #说明这是一个函数。
  7. print(isinstance(Foo.func,MethodType)) #False

三、函数的返回值

1.return的作用:结束一个函数的执行

2.首先返回值可以是任意的数据类型。

3.函数可以有返回值:如果有返回值,必须要用变量接收才有效果

也可以没有返回值:

  没有返回值的时候分三种情况:

    1.当不写return的时候,函数的返回值为None

    2.当只写一个return的时候,函数的返回值为None

    3.return None的时候,函数的返回值为None(几乎不用)

4.return返回一个值(一个变量)

5.return返回多个值(多个变量):多个值之间用逗号隔开,以元组的形式返回。

                接收:可以用一个变量接收,也可以用多个变量接收,返回几个就用几个变量去接收

  1. def firstvalue(a,b):
  2.  
  3. c = a + b
  4.  
  5. return c
  6.  
  7. def secondvalue(a,b):
  8.  
  9. c = a + b
  10.  
  11. return a,b,c

四、函数的参数

  1. 1.实参和形参
    形参:是函数定义时候定义的参数
    实参:函数调用的时候传进来的参数
    2.传递多个参数
    可以传递多个参数,多个参数之间用逗号隔开。
  1. 站在传参的角度上,调用函数时传参数有两种方式:
      1.按照位置传参数
      2.按照关键字传参数
  1. 用法:1.位置参数必须在关键字参数的前面
       2.对于一个参数只能赋值一次
  1. def my_max(a,b):#位置参数:按顺序定义参数
  2. if a>b:
  3. return a
  4. else:
  5. return b
  6. # 站在传参的角度上
  7. print(my_max(20,30))
  8. print(my_max(10,20))# 1.按照位置传参
  9. print(my_max(b=50,a=30))# 2.按照关键字传参
  10. print(my_max(10,b=30))#3.位置和关键字传参混搭
  11.  
  12. 传递多个参数,实现比大小的功能

3.默认参数

用法:为什么要用默认参数?将变化比较小的值设置成默认参数(比如一个班的男生多,女生就几个,就可以设置个默认值参数)

定义:默认参数可以不传,不传的时候用的就是默认值,如果传会覆盖默认值。

   默认的值是在定义函数的时候就已经确定了的

  1. def stu_info(name,sex = "male"):
  2. """打印学生信息函数,由于班中大部分学生都是男生,
  3. 所以设置默认参数sex的默认值为'male'
  4. """
  5. print(name,sex)
  6. stu_info('alex')
  7. stu_info('海燕','female')
  8.  
  9. 默认参数

4.动态参数

按位置传值多余的参数都由args统一接收,保存成一个元组的形式

按关键字传值接受多个关键字参数,由kwargs接收,保存成一个典的形式

  1. def fun(a,b,*args):
  2. sum=a+b
  3. for i in args:
  4. sum+=i
  5. return sum
  6. print(fun(1,5,6,4))#输出1+5+6+4的和

*args应用

  1. def fun(a,b,**kwargs):
  2. print(a,b,kwargs)
  3.  
  4. # 按照关键字传参数
  5. fun(a = 10,b = 20,cccc= 30,dddd = 50)#输出10 20 {'cccc': 30, 'dddd': 50}
  6.  
  7. def f(a,b,*args,defult=6,**kwargs):
  8. #位置参数,*args, 默认参数,**kwargs
  9. # print(a,b,args,defult,kwargs)
  10. return a,b,args,defult,kwargs
  11.  
  12. #传参数的时候:必须先按照位置传参数,再按照关键字传参数
  13. print(f(1,2,7,8,ccc=10,der=5))
  14.  
  15. *kwargs的应用

**kwargs应用

 

1.为什么要使用装饰器呢?

  装饰器的功能:在不修改原函数及其调用方式的情况下对原函数功能进行扩展

  装饰器的本质:就是一个闭包函数

  1. import time
  2. def wrapper(func):
  3. def inner():
  4. start=time.time()
  5. func()
  6. end=time.time()
  7. print(end-start)
  8. return inner
  9. @wrapper
  10. def kkk():#相当于kkk=wrapper(kkk)
  11. print('aaaaa')
  12. kkk()
  1. import time
  2. def timer(func):
  3. def inner(*args,**kwargs):
  4. start = time.time()
  5. re = func(*args,**kwargs)
  6. end=time.time()
  7. print(end- start)
  8. return re
  9. return inner
  10.  
  11. @timer #==> func1 = timer(func1)
  12. def func1(a,b):
  13. print('in func1')
  14. print(a,b)
  15.  
  16. @timer #==> func1 = timer(func1)
  17. def func2(a):
  18. print('in func2 and get a:%s'%(a))
  19. return 'fun2 over'
  20.  
  21. func1(1,2)
  22. print(func2('aaaaaa'))
  23.  
  24. 原函数带多个参数的装饰器

带多个参数的装饰器

  1. import time
  2. def timer(func):
  3. def inner(*args,**kwargs):
  4. start = time.time()
  5. re = func(*args,**kwargs)
  6. end=time.time()
  7. print(end - start)
  8. return re
  9. return inner
  10.  
  11. @timer #==> func1 = timer(func1)
  12. def jjj(a):
  13. print('in jjj and get a:%s'%(a))
  14. return 'fun2 over'
  15.  
  16. jjj('aaaaaa')
  17. print(jjj('aaaaaa'))
  18.  
  19. 带返回值的装饰器

带返回值的装饰器

二、开放封闭原则

1.对扩展是开放的

2.对修改是封闭的

 三、装饰器的固定结构

  1. import time
  2. def wrapper(func): # 装饰器
  3. def inner(*args, **kwargs):
  4. '''函数执行之前的内容扩展'''
  5. ret = func(*args, **kwargs)
  6. '''函数执行之前的内容扩展'''
  7. return ret
  8. return inner
  9.  
  10. @wrapper # =====>aaa=timmer(aaa)
  11. def aaa():
  12. time.sleep(1)
  13. print('fdfgdg')
  14. aaa()

四、带参数的装饰器

带参数的装饰器:就是给装饰器传参

        用处:就是当加了很多装饰器的时候,现在忽然又不想加装饰器了,想把装饰器给去掉了,但是那么多的代码,一个一个的去闲的麻烦,那么,我们可以利用带参数的装饰器去装饰它,这就他就像一个开关一样,要的时候就调用了,不用的时候就去掉了。给装饰器里面传个参数,那么那个语法糖也要带个括号。在语法糖的括号内传参。在这里,我们可以用三层嵌套,弄一个标识为去标识。如下面的代码示例

  1. # 带参数的装饰器:(相当于开关)为了给装饰器传参
  2. # F=True#为True时就把装饰器给加上了
  3. F=False#为False时就把装饰器给去掉了
  4. def outer(flag):
  5. def wrapper(func):
  6. def inner(*args,**kwargs):
  7. if flag:
  8. print('before')
  9. ret=func(*args,**kwargs)
  10. print('after')
  11. else:
  12. ret = func(*args, **kwargs)
  13. return ret
  14. return inner
  15. return wrapper
  16.  
  17. @outer(F)#@wrapper
  18. def hahaha():
  19. print('hahaha')
  20.  
  21. @outer(F)
  22. def shuangwaiwai():
  23. print('shuangwaiwai')
  24.  
  25. hahaha()
  26. shuangwaiwai()
  27.  
  28. 给装饰器加参数

装饰器开关

五、多个装饰器装饰一个函数

  1. def qqqxing(fun):
  2. def inner(*args,**kwargs):
  3. print('in qqxing: before')
  4. ret = fun(*args,**kwargs)
  5. print('in qqxing: after')
  6. return ret
  7. return inner
  8.  
  9. def pipixia(fun):
  10. def inner(*args,**kwargs):
  11. print('in qqxing: before')
  12. ret = fun(*args,**kwargs)
  13. print('in qqxing: after')
  14. return ret
  15. return inner
  16. @qqqxing
  17. @pipixia
  18. def dapangxie():
  19. print('饿了吗')
  20. dapangxie()
  21.  
  22. '''
  23. @qqqxing和@pipixia的执行顺序:先执行qqqxing里面的 print('in qqxing: before'),然后跳到了pipixia里面的
  24. print('in qqxing: before')
  25. ret = fun(*args,**kwargs)
  26. print('in qqxing: after'),完了又回到了qqqxing里面的 print('in qqxing: after')。所以就如下面的运行结果截图一样
  27. '''
  28.  
  29. 多个装饰器装饰一个函数

六、统计多少个函数被装饰了的小应用

  1. 统计多少个函数被我装饰了
  2. l=[]
  3. def wrapper(fun):
  4. l.append(fun)#统计当前程序中有多少个函数被装饰了
  5. def inner(*args,**kwargs):
  6. # l.append(fun)#统计本次程序执行有多少个带装饰器的函数被调用了
  7. ret = fun(*args,**kwargs)
  8. return ret
  9. return inner
  10.  
  11. @wrapper
  12. def f1():
  13. print('in f1')
  14.  
  15. @wrapper
  16. def f2():
  17. print('in f2')
  18.  
  19. @wrapper
  20. def f3():
  21. print('in f3')
  22. print(l)
  23.  
  24. 统计多少个函数被装饰了
  1. 内置函数
    1.eval,exec,和compile
  2.  
  3. eval("print(456)")#吧字符串转换成python代码去执行(有返回值)
    exec("print(7889)")#吧字符串转换成python代码去执行(无返回值)
    2.compile#做编译
  1. com=compile('1+2+3','',mode = 'eval')#节省时间
    print(eval(com))
    print(eval('1+2+3'))#这句效果和上面的compile()效果一样

3.type()

  1. 4.round精确度
    print(round(3.1415926,2))#保留两位
  1. 5.和数据结构相关的
    1.reversed()顺序的反转
    l=[1,2,3,4]
    print(list(reversed(l)))#是生成了一个新的列表,没有改变原来的列表(以后能不用reversed就不用reversed,用reverse
  2.  
  3. #l.reverse()#在现在的列表的基础上修改了,修改的是原来的列表
  1. 5.slice切片
    6.format()#除了格式化以外的作业
  2.  
  3. 6.setfrozenset(不可变的集合)就像listtuple
  4.  
  5. 7.zip()
  1. l=[1,2,3]
  2. l2=[4,5,6,7,8]
  3. print(zip(l,l2))
  4. print(list(zip(l,l2)))
  5. l3={'k':'v'}
  6. print(list(zip(l,l3)))
  1. 8.sortsorted
  1. l=[1,3,5,-2,-6]
  2. l.sort()
  3. print(l)
  4. l2=[1,3,5,-2,-6]
  5. print(sorted(l2))
  6. print(sorted(l2,key=abs))
  7. print(sorted(l2,key=abs,reverse=True))#默认从小到大排序,修改为True,则从大到小排序
  1. 9.map():我要对我的列表当中的每一个值去做函数里面的操作
  1. l=[1,2,3,4,5]
  2. def pow2(x):
  3. return x*x
  4. print(list(map(pow2,l)))
  1. 10.filter():从一个列表当中找到所有符合筛选条件的,在组成一个新列表
  1. def aaa(x):
  2. return x%2==1
  3. ret=list(filter(aaa,[1,2,54,3,6,8,17,9]))
  4. print(ret)
  1. 递归函数

1.什么是递归:在一个函数里在调用这个函数本身

  1. 一个数,除2直到不能整除2
  2. def cal(num):
  3. if num%2==0:#先判断能不能整除
  4. num=num//2
  5. return cal(num)
  6. else:
  7. return num
  8. print(cal(8))

匿名函数:也叫lambda表达式

1.匿名函数的核心:一些简单的需要用函数去解决的问题,匿名函数的函数体只有一行

2.参数可以有多个,用逗号隔开

3.返回值和正常的函数一样可以是任意的数据类型

  1. 请把下面的函数转换成匿名函数
  2. def add(x,y)
  3. return x+y
  4. add()
  5.  
  6. 结果:
  7. sum1=lambda x,y:x+y
  8. print(sum1(5,8))

三、列表推导式

  1. 30以内所有被3整除的数
  2. print(list([i for i in range(30) if i%3==0]))
  3.  
  4. 将一个字典的keyvalue对调
  1. mcase = {'a': 10, 'b': 34}
  2. res1 = {i:mcase[i] for i in mcase}
  3. res={mcase[i]:i for i in mcase }
  4. print(res1)
  5. print(res)

例二:合并大小写对应的value值,将k统一成小写

  1. mcase = {'a':10,'b':34,'A':7}
  2. res = {i.lower():mcase.get(i.lower(),0)+mcase.get(i.upper(),0) for i in mcase}
  3. print(res)

四、集合推倒式

例:计算列表中每个值的平方,自带去重功能

  1. l=[5,-5,1,2,5]
  2. print({i**2 for i in l})

高阶函数

map()传入的第一个参数是f,即函数对象本身。由于结果r是一个Iterator,Iterator是惰性序列,因此通过list()函数让它把整个序列都计算出来并返回一个list。

a='123'

def f(x):

return x

r=map(f,a)

print list(r)

reduce的用法。reduce把一个函数作用在一个序列[x1, x2, x3, ...]上,这个函数必须接收两个参数,reduce把结果继续和序列的下一个元素做累积计算,其效果就是:

reduce(f, [x1, x2, x3, x4]) = f(f(f(x1, x2), x3), x4)

filter()把传入的函数依次作用于每个元素,然后根据返回值是True还是False决定保留还是丢弃该元素。

defis_odd(n):
returnn
% 2==
1list(filter(is_odd,
[1,
2,
4,
5,
6,
9,
10,
15]))

排序也是在程序中经常用到的算法。无论使用冒泡排序还是快速排序,排序的核心是比较两个元素的大小。如果是数字,我们可以直接比较,但如果是字符串或者两个dict呢?直接比较数学上的大小是没有意义的,因此,比较的过程必须通过函数抽象出来

Python内置的sorted()函数就可以对list进行排序:

sorted(['bob',
'about',
'Zoo',
'Credit'],
key=str.lower, reverse=True)

①从参数方面来讲:

map()函数:

  map()包含两个参数,第一个是参数是一个函数,第二个是序列(列表或元组)。其中,函数(即map的第一个参数位置的函数)可以接收一个或多个参数。

reduce()函数:

reduce()
第一个参数是函数,第二个是
序列(列表或元组)。但是,其函数必须接收两个参数。

②从对传进去的数值作用来讲:

map()是将传入的函数依次作用到序列的每个元素,每个元素都是独自被函数“作用”一次;

reduce()是将传人的函数作用在序列的第一个元素得到结果后,把这个结果继续与下一个元素作用(累积计算),

最终结果是所有的元素相互作用的结果。

练习:

计算:lambda和reduce实现1到100的累加
fromfunctools
importreduce
print(reduce(lambdax,y:sum([x,y]),range(1,101)))
#第一个参数是一个函数,第二个参数是一个序列print(map(lambdax,y:sum([x,y]),range(1,101)))
#第一个参数是一个函数,第二个参数是一个序列print(list(map(lambdax,y:sum([x,y]),range(1,101),range(1,101))))
#第一个参数是一个函数,第二个参数是一个序列

模块

同一个目录 引入模块

import

from..import

这两种都会把函数执行一遍

import Firstmoudle

Firstmoudle.func(1,2)

# from Firstmoudle import func(全部*

from Firstmoudle import s 分成2行写

模块内容执行1次 只是把变量或者函数拿出来

# func(1,2)

reload(Firstmoudle)

Firstmoudle.func()

import sys

print sys.getdefaultencoding()

reload(sys)

sys.setdefaultencoding('utf_8')

print sys.getdefaultencoding()

不同文件夹下引用需要添加绝对路径或者相对路径

import sys

sys.path.append('C:\\Users\\thinkpad\\PycharmProjects\\untitled\\test\\test2')

import Firstmoudle

Firstmoudle.func()

  1.  

 

  1.  

Python学习【第5篇】:Python之函数(自定义函数,内置函数,装饰器,迭代器,生成器、模块)的更多相关文章

  1. python学习番外篇——字符串的数据类型转换及内置方法

    目录 字符串的数据类型转换及内置方法 类型转换 内置方法 优先掌握的方法 需要掌握的方法 strip, lstrip, rstrip lower, upper, islower, isupper 插入 ...

  2. 简学Python第三章__函数式编程、递归、内置函数

    #cnblogs_post_body h2 { background: linear-gradient(to bottom, #18c0ff 0%,#0c7eff 100%); color: #fff ...

  3. 生成器的send方法、递推函数、匿名函数及常用内置函数

    生成器的send方法 在使用yield方法创建生成器时,不仅可以使用next方法进行取值,还可以通过send方法向生成器的内部传值 什么是send方法? send方法相当于高级的next方法,send ...

  4. Python成长之路第二篇(1)_数据类型内置函数用法

    数据类型内置函数用法int 关于内置方法是非常的多这里呢做了一下总结 (1)__abs__(...)返回x的绝对值 #返回x的绝对值!!!都是双下划线 x.__abs__() <==> a ...

  5. Python开发【第四篇】: 三大器和内置函数

    内容概要 函数名 闭包 迭代器 生成器 推导式与表达式 内置函数 装饰器 初识递归 1.函数名 函数名的运用: 函数名是一个变量,但它是一个特殊的变量,与括号配合可以执行函数的变量. 01. 函数名的 ...

  6. Python学习(七)——匿名函数、map函数、filter函数、reduce函数与其他内置函数

    匿名函数 lambda x: x + 1 # lambda:定义匿名函数的关键字 # x:形参 # x+1:程序处理逻辑 fun = lambda x: x + 1 print(fun(5)) #6 ...

  7. python 内部函数,以及lambda,filter,map等内置函数

    #!/usr/bin/python #encoding=utf-8 def back(): return 1,2, "xxx" #python 可变参数 def test(*par ...

  8. Python函数之lambda,内置函数,yield生成器等

    lambda 1,用于处理简单逻辑 2,自动返回数据(return) 单参数 >>> func2 = lambda a: a+1>>> result = func2 ...

  9. python开发函数进阶:内置函数

    一,内置函数 #内置的模块#拿过来直接就用的:内置的函数 #!/usr/bin/env python #_*_coding:utf-8_*_ #内置的模块 #拿过来直接就用的:内置的函数 #作用域相关 ...

  10. python函数知识六 内置函数二、匿名函数与内置函数三(重要)

    19.内置函数二 abs():绝对值 lst = [1,2,-3,1,2,-5] print([abs(i) for i in lst]) enumerate("可迭代对象",&q ...

随机推荐

  1. unable to execute dex: multiple dex files Cocos2dxAccelerometer

    原文转载:http://discuss.cocos2d-x.org/t/conversion-to-dalvik-format-failed-unable-to-execute-dex-multipl ...

  2. 破解IntelliJ IDEA 2017

    一.下载地址 http://www.jetbrains.com/idea/ 二.下载破解jar包 http://idea.lanyus.com/ 2.1 将下载好的jar包放在IDEA的bin文件下 ...

  3. Hackerrank Connected Cell in a Grid

    Problem Statement You are given a matrix with m rows and n columns of cells, each of which contains ...

  4. C - Gr-idian MST

    Time limit : 2sec / Memory limit : 256MB Score : 500 points Problem Statement On an xy plane, in an ...

  5. Chrome格式化JavaScript

    在network或者source的tab中找到对应的JavaScript文件 重点在右下角的{}图标,点击一下,就会帮你自动格式化了 https://plus.google.com/+AddyOsma ...

  6. Consider using EXISTS instead of IN

    redgate给出的提示 https://documentation.red-gate.com/codeanalysis/performance-rules/pe019 In theory, EXIS ...

  7. NHibernate系列学习(二)-使用sql和hql以及linq

    1.本文主要介绍了NH的三种查询方式 2.界面查看 3.代码架构 4.代码详情 namespace KimismeDemo { public partial class Form2 : Form { ...

  8. vue杂记

    VUE杂记 声明式渲染 <div id="app"> {{ message }} </div> var app = new Vue({ el: '#app' ...

  9. Windows10开启热点

    1.以网线的连接方式,已经连接. 2.打开CMD 3. 开启热点 3.1设置热点名称和密码 netsh wlan set hostednetwork mode=allow ssid=name key= ...

  10. node 第三方包学习

    时间格式化 moment var moment = require('moment'); moment().format();