内置函数2 递归函数

Deadly 提交于 2020-01-30 09:59:07

列表和元祖

list : 将一个可迭代对象转换化列表(如果是一个字典,默认将key 作为列表的元素,那个值是不会加进来的)

tuple: 将一个可迭代对象转化成元组(如果是字典,默认将key作为列表的元素)

l = list({'k1':1,'k2':2})
print(l)
tu = tuple({'k1':1,'k2':2})
print(tu)

['k1', 'k2']
('k1', 'k2')

reversed : 将一个序列翻转,并返回此翻转序列的迭代器

l = [1,5,7,9,3,2,4]
print(list(reversed(l)))---------------------》[4, 2, 3, 9, 7, 5, 1]
  结果是一个迭代器  注意

如果不用 list 包起来的话 ---》<list_reverseiterator object at 0x00000000028E0A58>
 这样人是识别不了的  不然就for循环 可以循环打印出来     
l1 = [1,3,4,2,6]s1 = 'abcdefg'dic = {'name':'alex','age':1000,'hobby':'oldwomen'} # 不行print(reversed(l1))for i in reversed(l1):    print(i)for i in reversed(s1):    print(i)for i in reversed(dic): 字典是翻转不了的 报错!!!    print(i)

slice:构造一个切片对象,用于列表的切片,其实就是做一个切片的东西设好配置,对列表用就直接切之前配置好的。

l3 = [i for i in range(10,20)]
sli_obj = slice(0,5,2)
print(l3[sli_obj])
-----------------------0到5 就是10,11,12,13,14  步长2
            输出  [10, 12, 14]    

str: 将数据转化成字符串

format:与具体数据相关,用于计算各种小数,精算等,展示一个有点意思的 其他的一般用不到。

# print(format('test', '<20'))
# print(format('test', '>20'))
# print(format('test', '^20'))

----------------    下面是效果  
test                
                test
        test        

bytes : unicode -------->bytes 类型  ---其实就是一个单方面的转换  没什么卵用 知道就行了

a1 = '太白'
b1 = bytes(a1,encoding='utf-8')
print(b1,type(b1))
------------------------
输出    b'\xe5\xa4\xaa\xe7\x99\xbd' <class 'bytes'>

id  内存地址:

数字在-5~256 的都在小数据池中,剩下的所有正数 因为存在同一个代码块复用所以id一样,而-6至更小的小数都是重新开辟空间。    负数就是不同  记住
ord:输入字符 查找该字符编码 unicode 的位置 加括号就用
chr:输入位置数字 找出其对应的字符 unicode   和上面 呼应
ascii: 在ascii码中 返回该值,不是则返回他在Unicode中的位置(注意:返回的是十六进制)
print (ascii(' 中 ' ))   #  ' \u4e2d '
repr : 返回一个对象的string形式(原形毕露)。其实就是返回原原本本的,插一个比较重要的知识点
# 格式化输出 %r
# msg = 'alex 是 %r的人' % ('德高望重')
# print(msg)    

sorted:对所有可迭代的对象进行排序操作(立马有一个默认方法 reverse = False 不会显示 这个是从小到大,如果等于True 那就是从大到小)

l1 = [2,3,5,3,1,9,8,6]
l1.sort()
print(l1)
print(sorted(l1)) # 形成了一个新列表
print(l1) # 原列表不变
--------------------
sort  是只对列表可以用  --------------- 下面这个要注意  总结的时候就搞混了
l2 = [(1,1000),(2,18),(4,250),(3,500)]def func1(x):    return x[1]print(sorted(l2,key=func1,reverse=True))  #比的是第二位置的数  从大到小  [(1, 1000), (3, 500), (4, 250), (2, 18)]print(sorted(l2,key=func1))  #比的是第二位置上的数  默认 从小到大  [(2, 18), (4, 250), (3, 500), (1, 1000)]print(sorted(l2,reverse=True)) #写出等于True 从大到小(没写key= 没传元素进函数 直接比的第一位置数)[(4, 250), (3, 500), (2, 18), (1, 1000)]  #,直接比第一个   一般不写出reverse默认从小到大 里面内置方法是reverse=Falsel= [1,9,3,4,2,6,7,8]print(list(reversed(l)))   #这个是reversed(翻转)   不是 reverse 这个是sorted的内置方法reverseprint(sorted(l))

all : 可迭代对象中,全部都是True 才是True 全真 就真

any:可迭代对象中,有一个True 就是 True  有一个为真 就真

zip:函数用于将可迭代的对象作为参数,讲对象中对应的元素打包成一个个元组,然后返回这些元素组成的列表
   如果各个迭代器的元素 个数不一致,则返回列表长度和最短的对象相同
    记住  !!! 拉链方法!!!  看代码
l1 = [1,2,3,5,6,7]
tu1 = ('alex','太白', 'wusir', '女神')
dic = {'name': '日天', 'age':28, 'hobby': 'tea', 'weight':100}
print(zip(l1,tu1,dic))
for i in zip(l1,tu1,dic):
    print(i)
------------------
<zip object at 0x0000000002694188>
(1, 'alex', 'name')
(2, '太白', 'age')
(3, 'wusir', 'hobby')
(5, '女神', 'weight')
------------------------第二个元组中   只有4个元素 那么就最多4条数据,拉链方法
                                其他多的 没元素和他对齐 呈现一个列表了
                                  注意字典的话 就是key    没值的事情

filter : 过滤 出来的是迭代器-------

l1 = [i for i in range(10)]
def func1(x):
    return x % 2 == 0
print(list(filter(func1,l1))) #过滤,筛选出来的就是迭代器
print(next(filter(func1,l1)))  #next一下 就是一个值  0
----------------
 结果  [0, 2, 4, 6, 8]
          0    

map: 会根据提供的函数对指定序列做映射,  循环模式  下面展示 一题两做

l1 = [1,2,3,4]
def func(x):
    return x**2
print(list(map(func,l1)))

print([i**2 for i in l1])   # 列表推导式  一行      列表中每一个数的平方 也可以i*i
重 # print() sum reversed点 #可以有 key 的: min max map sorted filter zip

匿名函数: lambda 表达式

普通函数 有且只有返回值的函数才可以用匿名函数进行简化,一行函数 看下面 范例

 

def func2(x):
    return x*2
print(func2(2))
--------------------------
func2 = lambda x : x**2
print(func2(2))
-------------------------------------解释一波:lambda后面x 就是传到def func2括号里的
                                                            后面x*2  x怎么怎么样 就是return的
                                                        具体的我也没搞太懂

~~~~~~~~~~~~~~~~~~

l2 = (1,1000),(2,18),(4,250),(3,500)     照第二个值 从小到大 排序

print(sorted(l2,key=lambda x:x[1]))
-----------------------------------------------------------------------------
利用内置函数匿名函数将dic按照值进行排序。
dic={'k1':10,'k2':100,'k3':30}         

print(sorted(dic.items(),key=lambda x:x[1]))
----------------------------------------------------------
利用内置函数匿名函数 计算列表的每个数的2倍。

print(list(map(lambda x:x*2,[1,5,7,4,8])))
-------------------------------------------------
利用内置函数匿名函数,将值大于10的留下来。

print(list(filter(lambda x: x>10,[5,8,11,9,15])))

-------------------------------
# func = lambda x:x if x > 2 else x * 2  也可以三元运算  好像是这样说的 一种方式

 人理解函数,神理解递归~

默认递归深度 :998

n = 1
def func(x):
    print(x)
    x += 1
    func(x)
func(n)


也可以自己加
# import sys
# sys.setrecursionlimit(100000)
n = 1
def func(x):
    print(x)
    x += 1
    func(x)
func(n)      

 

# alex  比 wusir 大两岁 n = 4
# wusir 比日天 大两岁  n= 3
# 日天 比太白 大两岁  n = 2
# 太白 24岁 n = 1
-----------------
def age(n):
    if n == 1:
        return 24
    else:
        return age(n-1) + 2
print(age(4))

 

 
 

 

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!