python函数调用语句_python语句和函数

一、python基本文件操作

内建函数:open(filename,‘w/r/a’)打开文件,w 覆盖写,r 读取文件,a 保留已有内容增加添加写

read()读取/输入

readline()读取一行 readlines() 逐行读取

seek(x,y)文件移动 第一个参数表示偏移量,第二参数 0表示从文件开头偏移,1表示从当前位置偏移,2表示从文件结尾偏移

print(file.tell()) 显示文件指针的位置

write()输出

close()关闭文件

二、异常的检查和处理

异常是出现在错误时采用的正常的控制流以外的动作 检测到错误,引发异常,对异常进行捕获

try:

检测异常

except Exceptio【,reason】

异常处理代码

finally:

发现异常是否继续执行等操作

常见错误类型:

变量没有被定义:NameError ‘X’ is not defined

语法错误:SyntaxError:invalid syntax

索引异常:IndexError:string index out of rang 比如检索超过索引下标的值时

字典索引错误:KeyError:查找字典中没有的key

输入类型错误:ValueError:输入整数的位置被输入 了字符串等其他类型

属性错误:AttritubeError:‘int’ object has no attritube ‘append’ 列如整数类型不支持append

try:

year = int(input(‘请输入年份’))

except (ValueError,xxxError) as e:#检查测到非整数会执行下列代码,并把错误异常重写成e

else

继续执行

finaly

不管什么情况都会执行下面的函数

except exceptinon as e #不管是什么错误类型都会被catch

print(‘请输入整数 %s’ %e)

三、函数

book.txt name.txt weapon.txt

f= open('name.txt')

data = f.read()

print (data.split('|')) 根据分隔符来拆分字符串

f2 = open(weapon.txt)

i=1

for line in f2.readlines():

if i % 2 == 1:

print(line.strip('\n')) 去掉每行中的换行符\n

i++

f3 = open(book.txt)

print(f3.read().replace('\n','')) 将读取内容中的换行符换成空值,读取内容变成一整行,容易匹配

def find_item(hero)

with open('book.txt',encoding = GBK18030) as f:

data = f.read().replace('\n','')

name_num =re.findall(hero,data) 返回的是data中出现的所有hero

return len(name_num)

name_dict = {}

with open ('name.txt') as f:

for line in f:

names = line.spilt('|')

for n in names:

name_num = find_item(n) 返回任务出现的次数

name_dict[n] = name_num 将人物和出现的次数组合成字典

默认参数

def student(name,sex,age=6): 默认参数只能放在最后 传参时可以不传默认参数

可变长参数 *:

var1 = 1

def func(first,*other): first是必填参数,other可填可不填 必须放在最后 *other表示一个元组, 也可以不用* 直接定义一个元组,传参时直接传元组

def student(profile,*tuple):

out_put=" "

print(tuple)

for parameter in tuple:

if not out_put:

out_put = out_put + parameter

else:

out_put = out_put + ',' + parameter

return profile+': '+out_put

print(student(u'zhangsan',u'87kg',u'man',u'19'))# *tuple可以传一组数据

def student(profile,**kwargs):

out_put=" "

for name,age in kwargs.items(): #遍历字典中的内容

if not out_put:

out_put = out_put + name+age

else:

out_put = out_put + ',' + name+age

return profile+': '+out_put

print(student(u'student',zhagnsan='12',lisi='18'))# **kwags是一个字典,也可以直接传一个字典

global var1 将var1作用域修改为全局

var1 = 2

return = print(len(first)+len(other))

func(1,2,3)

# 经典参数实例

def fo(x,*args,y=2,**kwargs):

print(x)

print(y)

print(args)

print(kwargs)

fo(1,(1,2,3,),{'a':1,'b':'string'})

fo(1,*(1,2,3,),**{'a':1,'b':'string'},y=5)

1

2

((1, 2, 3), {'a': 1, 'b': 'string'})

{}

1

5

(1, 2, 3)

{'a': 1, 'b': 'string'}

函数迭代器和生成器

list【1,2,3】

it = iter(list) iter迭代 迭代器有next方法,每次只返回元组中的一个值

print (next(it))

def frange(start,end,step): 制作一个生成器(有迭代功能的函数,支持浮点数的range),每次只返回一个数值,next范围超过end会报错,

x=start

while x

yield x

x += step

for i in frange(10,20,0.5)

print(i)

匿名函数:lambda 表达式

参考文章:https://www.zhihu.com/question/20125256

def add(a,b):

return a+b

add(1,2)

等同于 add = lambda a,b : b+a

print(add(1,2))

扩展:使用不定长参数 add = lambda *args: sum(args)

map函数:

map(Fun,Seq) 返回的是一个序列, seq是一个元组或列表,作为fun的一个参数传入

def number(x):

return x**2

a = [2,3,4]

print(number(a[0]),number(a[1]),number(a[2]))

print(list(map(number,a))) #这里需要注意,python2中返回的是一个列表 python3中返回的是一个迭代器

python 内建函数

filter(function or none,iter)将满足func的iter值取出来返回;用来筛选迭代器中的值

a = 【1,2,3,4,5】 print(list(filter(lambda x:x>2,a))) python3中需要用list转化 不然不会被执行,会返回一个filter对象

map(func,*iter) 可变的iter

b = 【2,3,4,5,6】 print(list(lambda x,y:x+y,a,b)) 返回的是【3,5,9,11】

from functools import reduce

reduce(func,sequence[,initial]) 初始值可以省略 把序列中的初始值按照func计算后输出

print (reduce(lambda x,y:x+y,[1,2,3],1)) 返回7 ((1+1)+2)+3

zip(iter1[,iter2[...]]) 返回zip object

for i in zip((1,2,3),(1,2,3))

print i 返回(1,1) (2,2) (3,3)

可以用zip对字典中的key和value进行对调

dict = {'a':'aa','b':'bb'}

new_dict = zip(dict.values(),dict.keys())

print(dict(new_dict)) 返回{aa":'a','bb':'b'}

闭包 函数嵌套 外部函数的参数被内部函数引用叫闭包

def sun (a):

def add(b):

retunrn a+b

return add

sum2 = sum(2) 传入外面的参数值2 返回的是里面的函数

print (sum2(4)) 返回6 (2+4)给 里面的函数传值 返回的是里面的函数返回a+b

用闭包实现计数器功能:

def conter():

cnt =[0]

def add(): return lambda cnt[0] : cnt[0]+1

cnt[0]+=1

return cnt[0]

return add

print(conter())

备注:关于为什么要是用list定义变量解释如下

python在使用变量的时候遵循一个原则:LEGB,分别是局部 local,闭包enclosing ,全局globle ,模块builtin

你使用一个函数内的变量做运算,python就会从函数中找这个变量的定义,如果找不到就会报错,避免了误使用全局变量的情况;

如果要引用的变量在闭包中,没有定义在函数内,就可以用nonlocal声明一下,python就会从外层函数中寻找这个变量;如果使用了global关键字修饰内部函数的变量,函数运算时就会在全局中寻找这个变量;如果函数内只引用全局变量而不对它进行修改,可以不加globle关键字直接引用,如果要修改全局变量则不需要在函数中声明globle关键字。

以上例子中使用list就达到了使用nonlocal变量的功能,因为对列表的操作就是直接操作了内存的位置,对变量的操作时重新分配了一块新的内存,所以在内部函数操作列表也是相当于在操作外部函数的list

装饰器 也是闭包的一种用法

def new_tips(argv):

def tips(func):

def nei(a,b):

print('%s %s' %(argv,func__name__))

func(a,b)

return nei

return tips

@new_tips('test') new_tips是装饰函数,用来装饰传进来的函数式,可以简化函数的书写,使其更加优雅。

def test(a,b)

print(a+b)

print(test(1,2))

上下文自定义管理器

with open ('book.txt') as f: 等价于: try finally: 当出现异常的时候 with会自动关闭,

for line in f

print line

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值