函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段。python
函数能提升应用的模块性,和代码的重复利用率。你已经知道Python提供了许多内建函数,好比print()。但你也能够本身建立函数,这被叫作用户自定义函数。express
你能够定义一个由本身想要功能的函数,如下是简单的规则:数组
语法:app
#定义函数 def printme (abc): "打印传入的字符串到标准显示设备上" print(abc) return printme("第一次调用自定义函数!") printme("再次调用同一函数")
以上实例输出结果:函数
第一次调用自定义函数!
再次调用同一函数
按值传递参数和按引用传递参数性能
全部参数(自变量)在python里都是按引用传递,若是你在函数里修改了参数,那么在调用这个函数的函数里,原始的参数也被改变了。例如:ui
def changeme(mylist): "修改传入的列表" mylist.append([1,2,3,4]); print("函数内取值",mylist) return
#调用changme函数 mylist = [10,20,30]; changeme(mylist); print("函数外取值:",mylist)
传入函数的和在末尾添加新内容的对象用的是同一个引用,故输出结果以下:spa
函数内取值: [10, 20, 30, [1, 2, 3, 4]]
函数外取值: [10, 20, 30, [1, 2, 3, 4]]
参数code
如下是调用函数时可以使用的正式参数类型:orm
必备参数
必备参数须以正确的顺序传入函数,调用时的数量必须和声明时的同样
用户printme()函数,你必须传入一个参数,否则会出现语法错误:
#可写函数说明 def printme(str): "打印任何传入的字符串" print(str) return#调用printme函数 printme()
以上实例输出结果:
Traceback (most recent call last): File "F:/python/procject/day4/函数.py", line 26, in <module> printme() TypeError: printme() missing 1 required positional argument: 'str'
关键字参数:
关键字参数和函数调用关系紧密,函数调用使用关键字参数来肯定传入的参数值。
使用关键字参数容许函数调用时参数的顺序与声明时不一致,由于python解释器可以用参数名匹配参数值。
如下实例在函数printme()调用时使用参数名:
#可写函数说明 def printme(str): "打印任何传入的字符串" print(str) return
#调用printme函数 printme(str = "My string")
以上实例输出结果:
My string
下例能将关键字参数顺序不重要展现得更清楚
def printinfo(name,age): "打印任何传入的字符串" print("Name:",name) print("Age:",age) return #调用printinfo函数 printinfo(age=50,name="miki")
以上实例输出结果:
Name: miki
Age: 50
缺省参数
调用函数时,缺省参数的值若是没有传入,则被认为是默认值 ,下例会打印默认的age,若是age没有被传入:
#可写函数说明 def printinfo(name,age = 35): "打印任何传入的字符串" print("Name:",name) print("Age:",age) return #调用printinfo函数 printinfo(age=50,name="miki") printinfo(name="miki")
以上实例输出结果:
Name: miki Age: 50 Name: miki Age: 35
匿名函数
python使用lambda来建立匿名函数:
语法:
lambda函数的语法只包含一个语句,以下:
lambda[arg1[arg2,arg,.....agrn]]:expression
以下实例:
sum = lambda arg1,arg2:arg1+arg2; #调用函数 print("相加后的值为:",sum(10,20)) print("相加后的值为:",sum(20,20))
以上实例输出结果:
相加后的值为: 30
相加后的值为: 40
return语句
return语句[表达式]退出函数,选择性地向调用方返回一个表达式,不带参数值的return语句返回None。以前的例子都没有示范如何返回数值,下例便告诉你怎么作:
def sum(arg1,arg2): # 返回2个参数的和." total = arg1 + arg2 print("函数内:",total) return total #调用sum函数 total = sum(10,20)
以上实例输出结果:
函数内: 30
一个程序的全部的变量并非在哪一个位置均可以访问的。访问权限决定于这个变量是在哪里赋值的。变量的做用域决定了在哪一部分程序你能够访问哪一个特定的变量名称。两种最基本的变量做用域以下:
定义在函数内部的变量拥有一个局部做用域,定义在函数外的拥有全局做用域。
局部变量只能在其被声明的函数内部访问,而全局变量能够在整个程序范围内访问。调用函数时,全部在函数内声明的变量名称都将被加入到做用域中。以下实例:
total = 0 def sum(arg1,arg2): #返回2个参数的和” total = arg1+arg2 #total在这里是局部变量 print("函数内是局部变量:",total) return total #调用函数 sum(10,20) print("函数外是全局变量:",total)
以上实例输出结果:
函数内是局部变量: 30
函数外是全局变量: 0
变量能够指向函数,函数的参数能接收变量,那么一个函数就能够接收另外一个函数做为参数,这种函数就称之为高阶函数。
def add(x,y,f): return f(x) + f(y) res = add(3,-6,abs) #abc 取绝对值 print(res)
初学者的了解,分类可能不许确,一块儿交流。
1、数学运算类
abs(x) | 求绝对值 一、参数能够是整型,也能够是复数 二、若参数是复数,则返回复数的模 |
complex([real[, imag]]) | 建立一个复数 |
divmod(a, b) | 分别取商和余数 注意:整型、浮点型均可以 |
float([x]) | 将一个字符串或数转换为浮点数。若是无参数将返回0.0 |
int([x[, base]]) | 将一个字符转换为int类型,base表示进制 |
long([x[, base]]) | 将一个字符转换为long类型 |
pow(x, y[, z]) | 返回x的y次幂 |
range([start], stop[, step]) | 产生一个序列,默认从0开始 |
round(x[, n]) | 四舍五入 |
sum(iterable[, start]) | 对集合求和 |
oct(x) | 将一个数字转化为8进制 |
hex(x) | 将整数x转换为16进制字符串 |
chr(i) | 返回整数i对应的ASCII字符 |
bin(x) | 将整数x转换为二进制字符串 |
bool([x]) | 将x转换为Boolean类型 |
2、集合类操做
basestring() | str和unicode的超类 不能直接调用,能够用做isinstance判断 |
format(value [, format_spec]) | 格式化输出字符串 格式化的参数顺序从0开始,如“I am {0},I like {1}” |
unichr(i) | 返回给定int类型的unicode |
enumerate(sequence [, start = 0]) | 返回一个可枚举的对象,该对象的next()方法将返回一个tuple |
iter(o[, sentinel]) | 生成一个对象的迭代器,第二个参数表示分隔符 |
max(iterable[, args...][key]) | 返回集合中的最大值 |
min(iterable[, args...][key]) | 返回集合中的最小值 |
dict([arg]) | 建立数据字典 |
list([iterable]) | 将一个集合类转换为另一个集合类 |
set() | set对象实例化 |
frozenset([iterable]) | 产生一个不可变的set |
str([object]) | 转换为string类型 |
sorted(iterable[, cmp[, key[, reverse]]]) | 队集合排序 |
tuple([iterable]) | 生成一个tuple类型 |
xrange([start], stop[, step]) | xrange()函数与range()相似,但xrnage()并不建立列表,而是返回一个xrange对象,它的行为与列表类似,可是只在须要时才计算列表值,当列表很大时,这个特性能为咱们节省内存 |
3、逻辑判断
all(iterable) | 一、集合中的元素都为真的时候为真 二、特别的,若为空串返回为True |
any(iterable) | 一、集合中的元素有一个为真的时候为真 二、特别的,若为空串返回为False |
cmp(x, y) | 若是x < y ,返回负数;x == y, 返回0;x > y,返回正数 |
4、反射
callable(object) | 检查对象object是否可调用 一、类是能够被调用的 二、实例是不能够被调用的,除非类中声明了__call__方法 |
classmethod() | 一、注解,用来讲明这个方式是个类方法 二、类方法便可被类调用,也能够被实例调用 三、类方法相似于Java中的static方法 四、类方法中不须要有self参数 |
compile(source, filename, mode[, flags[, dont_inherit]]) | 将source编译为代码或者AST对象。代码对象可以经过exec语句来执行或者eval()进行求值。 一、参数source:字符串或者AST(Abstract Syntax Trees)对象。 二、参数 filename:代码文件名称,若是不是从文件读取代码则传递一些可辨认的值。 三、参数model:指定编译代码的种类。能够指定为 ‘exec’,’eval’,’single’。 四、参数flag和dont_inherit:这两个参数暂不介绍 |
dir([object]) | 一、不带参数时,返回当前范围内的变量、方法和定义的类型列表; 二、带参数时,返回参数的属性、方法列表。 三、若是参数包含方法__dir__(),该方法将被调用。当参数为实例时。 四、若是参数不包含__dir__(),该方法将最大限度地收集参数信息 |
delattr(object, name) | 删除object对象名为name的属性 |
eval(expression [, globals [, locals]]) | 计算表达式expression的值 |
execfile(filename [, globals [, locals]]) | 用法相似exec(),不一样的是execfile的参数filename为文件名,而exec的参数为字符串。 |
filter(function, iterable) | 构造一个序列,等价于[ item for item in iterable if function(item)] 一、参数function:返回值为True或False的函数,能够为None 二、参数iterable:序列或可迭代对象 |
getattr(object, name [, defalut]) | 获取一个类的属性 |
globals() | 返回一个描述当前全局符号表的字典 |
hasattr(object, name) | 判断对象object是否包含名为name的特性 |
hash(object) | 若是对象object为哈希表类型,返回对象object的哈希值 |
id(object) | 返回对象的惟一标识 |
isinstance(object, classinfo) | 判断object是不是class的实例 |
issubclass(class, classinfo) | 判断是不是子类 |
len(s) | 返回集合长度 |
locals() | 返回当前的变量列表 |
map(function, iterable, ...) | 遍历每一个元素,执行function操做 |
memoryview(obj) | 返回一个内存镜像类型的对象 |
next(iterator[, default]) | 相似于iterator.next() |
object() | 基类 |
property([fget[, fset[, fdel[, doc]]]]) | 属性访问的包装类,设置后能够经过c.x=value等来访问setter和getter |
reduce(function, iterable[, initializer]) | 合并操做,从第一个开始是前两个参数,而后是前两个的结果与第三个合并进行处理,以此类推 |
reload(module) | 从新加载模块 |
setattr(object, name, value) | 设置属性值 |
repr(object) | 将一个对象变幻为可打印的格式 |
slice() | |
staticmethod | 声明静态方法,是个注解 |
super(type[, object-or-type]) | 引用父类 |
type(object) | 返回该object的类型 |
vars([object]) | 返回对象的变量,若无参数与dict()方法相似 |
bytearray([source [, encoding [, errors]]]) | 返回一个byte数组 一、若是source为整数,则返回一个长度为source的初始化数组; 二、若是source为字符串,则按照指定的encoding将字符串转换为字节序列; 三、若是source为可迭代类型,则元素必须为[0 ,255]中的整数; 四、若是source为与buffer接口一致的对象,则此对象也能够被用于初始化bytearray. |
zip([iterable, ...]) | 实在是没有看懂,只是看到了矩阵的变幻方面 |
5、IO操做
file(filename [, mode [, bufsize]]) | file类型的构造函数,做用为打开一个文件,若是文件不存在且mode为写或追加时,文件将被建立。添加‘b’到mode参数中,将对文件以二进制形式操做。添加‘+’到mode参数中,将容许对文件同时进行读写操做 一、参数filename:文件名称。 二、参数mode:'r'(读)、'w'(写)、'a'(追加)。 三、参数bufsize:若是为0表示不进行缓冲,若是为1表示进行行缓冲,若是是一个大于1的数表示缓冲区的大小 。 |
input([prompt]) | 获取用户输入 推荐使用raw_input,由于该函数将不会捕获用户的错误输入 |
open(name[, mode[, buffering]]) | 打开文件 与file有什么不一样?推荐使用open |
打印函数 | |
raw_input([prompt]) | 设置输入,输入都是做为字符串处理 |
其余
help()--帮助信息
内置函数,通常都是由于使用频率比较频繁或是是元操做,因此经过内置函数的形式提供出来,经过对python的内置函数分类分析能够看出来:基本的数据操做基本都是一些数学运算(固然除了加减乘除)、逻辑操做、集合操做、基本IO操做,而后就是对于语言自身的反射操做,还有就是字符串操做,也是比较经常使用的,尤为须要注意的是反射操做。