python — lambda表达式与内置函数
目录
1 lambda表达式 (匿名函数)
用于表示简单的函数
lambda表达式,为了解决简单函数的情况:
def func(a1,a2): =====> func = lambda a1,a2:a1+a2 # 函数直接得到返回值,这里隐藏了return return a1+a2 简化
# 三元运算,为了解决简单的if else的情况,如: if 1 == 1: a = 123 else: a = 456 a = 123 if 1 == 1 else 456 # lambda表达式,为了解决简单函数的情况,如: def func(a1,a2): return a1 + 100 func = lambda a1,a2: a1+100
func1 = lambda : 100 func2 = lambda x1: x1 * 10 func3 = lambda *args,**kwargs: len(args) + len(kwargs) data = 100 func4 = lambda a1: a1 + data v = func4(1) print(v) data = 100 def func(): data = 1000 func4 = lambda a1: a1 + data v = func4(1) print(v) func() func5 = lambda n1,n2: n1 if n1 > n2 else n2 v = func5(1111,2) print(v)
lambda表达式只能用一行来表示函数,只能用参数来作为变量。
练习题
# 练习题1 user_list = [] def func0(x): v = user_list.append(x) return v result = func0('alex') print(result) # 练习题2 def func0(x): v = x.strip() return v result = func0(' alex ') print(result) ############## 总结:列表所有方法基本上都是返回none;字符串的所有方法基本上都是返回新值 ################# # 练习题3 user_list = [] func1 = lambda x: user_list.append(x) v1 = func1('alex') print(v1) print(user_list) # 练习题4 func1 = lambda x: x.split('l') v1 = func1('alex') print(v1) # 练习题5 func_list = [lambda x:x.strip(), lambda y:y+199,lambda x,y:x+y] v1 = func_list[0]('alex ') print(v1) v2 = func_list[1](100) print(v2) v3 = func_list[2](1,2) print(v3)
总结:
列表所有方法基本上都是返回none,字符串的所有方法基本上都是返回新值。
2 内置函数
函数分为:自定义函数 和 内置函数
目前python的内置函数分为几大类:
-
1.强制转换
bool() / int() / str() / list() / dict() /tuple() / set()
-
2.输入输出
print() / input()
-
3.其他
len() / open() / id() / range() / type()
-
4.数学相关
-
-
abs() 绝对值
v = abs(-1) print(v) # 1
-
float() 转换成浮点型(小数)
v = 55 v1 = float(v) print(v1) # 55.0
-
max() 找到最大值
v = [1,2,33,5,9] result = max(v) print(result) # 33
-
min() 找到最小值
v = [1,2,311,11,8] v2 = min(v) print(v2) # 1
-
sum() 求和
v = [1,2,311,11,9] v1 = sum(v) print(v1) # 334
-
divmod() 两数相除的商和余数
a,b = divmod(1001,5) print(a,b) # 200 1
补充:字符串格式化:'你少妻-%s' %(i,) ------>后面%(i,)如果括号中只有一个变量,可以写成:'你少妻-%s' %i
# 练习题 请通过分页对数据进行展示 """ 要求: 每页显示10条数据 让用户输入要查看的页面:页码 """ user_list = [] for i in range(1,836): temp = {'name':'你少妻-%s' %i,'email':'123%s@qq.com' %i } user_list.append(temp) # 数据总条数 total_count = len(user_list) # 每页显示10条 per_page_count= 10 # 总页码数 max_page_num,a = divmod(total_count,per_page_count) if a>0: max_page_num += 1 while true: pager = int(input('要查看第几页:')) if pager < 1 or pager > max_page_num: print('页码不合法,必须是 1 ~ %s' %max_page_num ) else: """ # 第1页:user_list[0:10] -> 0123456789 # 第2页:user_list[10:20] # 第3页:user_list[20:30] ... """ start = (pager-1) * per_page_count end = pager * per_page_count data = user_list[start:end] for item in data: print(item)
-
7.pow
pow(x,y) 表示x的y次方
v = pow(2,3) print(v) # 8
-
8.round 保留小数点后几位小数,还会四舍五入。
v = round(1.127,1/2) print(v) # 1.1 / 1.13
-
-
-
5.进制转换相关
-
bin() 将十进制转换成二进制
num = 13 v1 = bin(num) print(v1) # 0b1101
-
oct() 将十进制转换成八进制
num = 8 v1 = oct(num) print(v1) # 0o10
-
int() 将其他的进制转换成十进制
# 二进制转化成十进制 v1 = '0b1101' result = int(v1,base=2) print(result) # 13 # 八进制转化成十进制 v1 = '0o1101' result = int(v1,base=8) print(result) # 十六进制转化成十进制 v1 = '0x1101' result = int(v1,base=16) print(result)
-
hex() 将十进制转换成十六进制
num = 16 v1 = hex(num) print(v1) # 0x10
练习题
# 1字节等于8位 # ip: 192.168.12.79 -> 001010010 . 001010010 . 001010010 . 001010010 # 1. 请将 ip = "192.168.12.79" 中的每个十进制数转换成二进制并通过,连接起来生成一个新的字符串。 ip = "192.168.12.79" ip_list = ip.split('.') # ['192','168','12','79'] result = [] for item in ip_list: result.append(bin(int(item))) print(','.join(result)) # 2. 请将 ip = "192.168.12.79" 中的每个十进制数转换成二进制: # 0010100100001010010001010010001010010 -> 十进制的值。 # 3232238671 ip = "192.168.12.79" ip1 = ip.split('.') lis = [] for i in ip1: lis.append(bin(int(i))) # val = ','.join(lis) # b = val.replace('0b', '') # b1 = b.split(',') b1 = ','.join(lis).replace('0b', '').split(',') e = [] #f or c in b1: for c in ','.join(lis).replace('0b', '').split(','): if len(c) < 8: val = 8 - len(c) d = list(c) d.insert(0,'0' * val) d1 = ''.join(d) e.append(d1) else: e.append(c) f = ''.join(e) f1 = int(f,base = 2 ) print(f1)
-
-
6.编码相关
-
chr 将十进制数字转换成unicode编码中的对应字符串
v = chr(65) print(v) # a
-
ord 根据字符在unicode编码中找到其对应的十进制
v = ord('中') print(v) # 20013
-
应用:
import random v = random.randint(65,90) print(v) # 随机获得65~90之间的数字 import random data = [] for i in range(6) v = random.randint(65,90) data.append(chr(v)) print(''.join(data)) # 6位随机字符串验证码 import random def get_random_code(length=6): data = [] for i in range(length): v = random.randint(65,90) data.append(chr(v)) return ''.join(data) code = get_random_code() print(code) # 6位随机字符串验证码
import random # 导入一个模块 v = random.randint(起始,终止) # 得到一个随机数
-
-
7.高级一点的内置函数
-
map 循环每个元素(第二个参数),然后让每个元素执行函数(第一个参数),将每个函数执行的结果保存到新的列表中,并返回。
v1 = [11,22,33,44] # map(x,v1) 第一个参数必须是函数,第二个参数必须是可迭代类型(可以被for循环的) def func(arg): print(arg) # map(func,v1) # 执行后并不打印arg,这是py3的一个特性,py3现在还不执行以后会执行 result = map(func,v1) # 然后将函数的返回值添加到一个[]中 # print(result) py2会直接返回列表 # print(result) py3不会,会得到一个对象/东西,想返回列表的话需要强制转换成列表 print(list(ruselt)) # result得到的是一个对象<map.objecta……>,需要list()才能打印列表
v1 = [11,22,33,44] result = map(lambda x:x+100,v1) print(list(result)) # 特殊
-
filter
result = filter(函数,参数)
v1 = [11,22,33,'asd',44,'xf'] def func(x): if type(x) == int: return true return false result = filter(func,v1) # [11,] print(list(result)) result = filter(lambda x: true if type(x) == int else false ,v1) print(list(result)) result = filter(lambda x: type(x) == int ,v1) print(list(result))
-
reduce 累计得到一个结果
reduce现在不在py3的内置函数种了 ,但py2的内置函数里包含。
import functools v1 = ['wo','hao','e'] def func(x,y): return x+y result = functools.reduce(func,v1) print(result) result = functools.reduce(lambda x,y:x+y,v1) print(result)
-
-
8.类相关的
-
type,查看类型
class foo: pass obj = foo() if type(obj) == foo: print('obj是foo类的对象')
-
issubclass
判断某个类是不是另一个类或其基类的子类。
issubclass(类1,类2) 类1—>子类名,类2—>基类名
class base: pass class base1(base): pass class foo(base1): pass class bar: pass print(issubclass(bar,base)) print(issubclass(foo,base))
-
isinstance
判断某个对象是否是某个类或其基类的实例(对象)
class base(object): pass class foo(base): pass obj = foo() print(isinstance(obj,foo)) # 判断obj是否是foo类或其基类的实例(对象) print(isinstance(obj,base)) # 判断obj是否是foo类或其基类的实例(对象)
-
super
class base(object): def func(self): print('base.func') return 123 class foo(base): def func(self): v1 = super().func() print('foo.func',v1) obj = foo() obj.func() # super().func() 去父类中找func方法并执行
class bar(object): def func(self): print('bar.func') return 123 class base(bar): pass class foo(base): def func(self): v1 = super().func() print('foo.func',v1) obj = foo() obj.func() # super().func() 根据类的继承关系,按照顺序挨个找func方法并执行(找到第一个就不在找了)
class base(object): # base -> object def func(self): super().func() print('base.func') class bar(object): def func(self): print('bar.func') class foo(base,bar): # foo -> base -> bar pass obj = foo() obj.func() # 多继承 # super().func() 根据self对象所属类的继承关系,按照顺序挨个找func方法并执行(找到第一个就不在找了)
super().要查找的方法
super().func() 根据self对象所属类的继承关系(从左向右依次查找),按照顺序挨个找func方法并执行(找到第一个就不再找了)
super 遵循mro顺序查找上一个类的
supper().func()不是查找父类,而是根据mro顺序,找到自己对应的下一个类
-