【Python 递归哈数&内置函数 07】

一、 递归函数 -->自己调用自己

def wahaha():
    print('wahaha')
    wahaha()
wahaha()
# 官网规定的递归的最大次数是1000次

#案例

# l=[1,2,3,4,[5,6,7,8[9,10,11,12]]]  求这个列表中所有元素的和
l=[1,2,3,4,[5,6,7,8,[9,10,11,12]]]
sum_n=0
def sum_clac(lst):
    global sum_n
    for i in lst:
        if type(i) is list:
            sum_clac(i)
        elif type(i) is int or type(i) is float:
            sum_n += i
    return sum_n
ret=sum_clac(l)
print(ret)  #78

二、内置函数

1、eval函数 -->把字符串的组成的内容当做Python的代码来执行,并返回值

2、exec函数 -->把字符串的组成的内容当做Python的代码来执行,没有返回值

a = input('>>>>') #输入:1+2
print(a) #1+2
print(eval(a)) #3
print(exec(a)) #None

3、callable 名字后面可以加()才可以被调用

   --->dir查看一个函数可以调用那些方法

a =1
print(callable(a)) #False

b = lambda :1
print(callable(b)) #True

4、print

print(1,2) #1 2 #默认已空格进行的分隔
print(1,2,end='*') #1 2*  -->end是已什么结尾的,默认已换行符(\n)进行的换行,可以用end自定义自己所需要的结尾方式
print(1,2,sep=',') #1,2 -->sep已什么分隔的

5、99乘法表

#99乘法表
for i in range(1,10):
    for j in range(1,i+1):
        print('%d*%d=%d'%(i,j,i*j),end=' ')

    print('')

6、和数字相关的函数

ret = divmod(10,3) #divmod返回(除,余)
print(ret) #(3, 1)

ret1 = round(1.2345,2) #round小数取几位
print(ret1) #1.23

ret2 = pow(2,3) #2的3次方,叫幂
print(ret2) #8
#2的3次方还可以这么写
print(2**3)
# 字典里面的数求和
dic = {'a':50,'b':100}
ret3=sum(dic[k] for k in dic) #这里面用到了生成器函数
print(ret3) #150

7、字符相关的内置函数

 

 常用ord,chr,repr

1)ord把十进制的转换成16进制,chr刚好相反把16进制转换成10进制

print(ord('a')) #97
print(chr(97)) #a

有什么用 --验证码收到的随机数(数字能随机,但是字符是不能随机的,想要字符随机怎么办?把数字组合后然后用chr转换)

2)repr 打印某个变量值的时候更便于区分类型

print(repr('123'))
print(repr(123))
print(123)
print('123')

执行结果:
'123'
123
123
123
常规打印的时候是区分不出来字符串还是int类型的数字,为了区分可以用repr修饰

3)reverse()  反转,类似于[::-1] 专门给list用的

  reversed() 是一个内置函数,也是反转,但是不会改变list,返回的是一个迭代器

l = [1,3,6,2]
l.reverse()
print(l) #[2, 6, 3, 1]

ret = reversed(l)
print(ret) #<list_reverseiterator object at 0x103ce8f70>
print(l) #[1, 3, 6, 2] 不会改变list
for i in ret:
    print(i,end=' ') #2 6 3 1

从上面两个执行的结果可以看出来,reversed()确实不会改变list本身,他的返回结果是一个迭代器,而reverse()的确是会改变list列表本身的

8、filter、map都是一个返回值为迭代器的函数   --》filter和map的意思就是循环迭代里面的每一个值(比如下面的题:循环迭代lst里面的每一个值 )

lst = [1,2,3,4,5,6,7,8,9,10]
ret1 = filter(lambda n:n%3==0,lst)
print(ret1) #<filter object at 0x100adefa0>
print(ret1.__next__()) #3

ret2 = map(lambda n:n*2,lst)
print(ret2) #<map object at 0x100adee80>
print(ret2.__next__()) #2

9、zip拉链

a = [1,2,3,4,5]
b = ['a','b','c','d']
ret = zip(a,b)
for i in ret:
    print(i)

#执行结果:
(1, 'a')
(2, 'b')
(3, 'c')
(4, 'd')

把两个列表组合在一起,组合的元素的个数必须是相同的

a = [1,2,3,4,5]
b = ['a','b','c','d']
c= ['换手率','涨跌幅']
ret = zip(a,b,c)
for i in ret:
    print(i)

#执行结果:
(1, 'a', '换手率')
(2, 'b', '涨跌幅')

从上面两个例子可以看出来,zip是可以组合列表的,但是组合时被组合的列表都是需要相同的元素

# 练习题
现有两个元组(('a'),('b')),(('c'),('d')),
请使用python中匿名函数生成列表[{'a':'c'},{'b':'d'}]

tup1 = (('a'),('b'))
tup2 = (('c'),('d'))
tup3 = zip(tup1,tup2)
iter = map(lambda tu:{tu[0]:tu[1]},tup3)
iter = map(lambda tu:tu,tup3) #[('a', 'c'), ('b', 'd')]  -->得到一个tu,返回一个tu
print(list(iter))
''' map循环ret里面每一个值,每一个值都是一个k,v
得到一个tu,返回一个字典{tu[0]:tu[1]},这样会生成一个iterator  '''

匿名函数lambda 常和map、filter、sorted、min、max拼接使用

10、min,max

ret1 = min(1,2,3,4,5)
print(ret1) #1
ret2 = min([1,2,3,-4,5],key=abs)
# abs是取绝对值的意思
print(ret2) #1
ret3 = min([1,2,3,-4,5],key=lambda n:n%2)
# lambda n:n%2 ==> 得到一个n,然后返回n除以2取余的数
# min([1,2,3,-4,5],key=lambda n:n%2) 取余最小的数
print(ret3) #2

max和min一样的用法

11、排序 sorted  -->从小到大排序

l = [23,-45,43,-66,11,-22]
ret = sorted(l)
print(ret) #[-66, -45, -22, 11, 23, 43]
ret1 = sorted(l,reverse=True,key=lambda n:n%10)
print(ret1) #[-22, -45, -66, 23, 43, 11]

#reverse 列表反转
posted @ 2022-04-22 18:07  尘封~~  阅读(63)  评论(0编辑  收藏  举报