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<end:

    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

 

posted @ 2019-06-11 08:49  头大点怎么了  阅读(550)  评论(0编辑  收藏  举报