列表和元祖
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))
来源:https://www.cnblogs.com/single82/p/9520045.html