ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

python-常用内置函数和迭代器(四)

2021-11-19 17:33:03  阅读:144  来源: 互联网

标签:__ 内置 迭代 python iter next .__ print


目录

1. 常用内置函数

1.1 map()

# map()  # 映射
l = [11, 22, 33, 44]
res = map(lambda x: x + 1, l)  # 循环获取列表中的每个元素并交给匿名函数保存返回值
print(list(res))  # [12, 23, 34, 45]

1.2 zip()

# zip() 拉链  按最少元素
l1 = [1, 2, 3, 4, 5]
l2 = ['jason', 'tony', 'xxx', 'tom', 'bob']
res = zip(l1, l2)
print(list(res))
# [(1, 'jason'), (2, 'tony'), (3, 'xxx'), (4, 'tom'), (5, 'bob')]

1.3 max()和min()

# max()求最大值 min()求最小值
l3 = [115, 292, 303, 414, 526, 809, 910, 101]
print(max(l3))  # 910
print(min(l3))  # 101

# 如果只接字典时会将K值进行比较
d1 = {"alex": 1000000,
      "tony": 20000,
      "jason": 3000000,
      "tom": 8900000000,
      }

print(max(d1, key=lambda key: d1[key]))  # tom  循环取值再比较大小,返回K
print(min(d1, key=lambda key: d1[key]))  # tony

1.4 filter()

# filter() 过滤
l3 = [115, 292, 303, 414, 526, 809, 910, 101]
res = filter(lambda x: x > 400, l3)
print(list(res))  # [414, 526, 809, 910]

1.5 reduce()

# reduce() 归总
from functools import reduce

l3 = [115, 292, 303, 414, 526, 809, 910, 101]
res1 = reduce(lambda x, y: x + y, l3)
res2 = reduce(lambda x, y: x + y, l3, 100)  # 还可以继续添加额外的元素
print(res1) # 3470
print(res2) # 3570

2. 可迭代对象

  1. 迭代:迭代即更新换代,每次的更新都必须依赖上一次的结果
    迭代提供了一种不依赖索引取值的方
  2. 可迭代对象:内置 __intr__方法的都称之为可迭代对象,内置可通过.的方式查看
  3. 双下滑线开头双下滑线结尾的方法叫双下方法名,面向对象的时候为了与隐藏变量名区分开
# 通过变量名.__查看是否有intr
i = 12  # 没有
f = 11.11  # 没有
s = 'jason'  # 有
l = [111,22,33,4]  # 有
d = {'username':'jason','pwd':123}  # 有
t = (11,22,33)  # 有
se = {11,22,33}  # 有
b = True  # 没有
file = open(r'a.txt','w',encoding='utf8')

"""
含有__iter__的有
    字符串 列表 字典 元组 集合 文件对象
上述通常为可迭代对象
"""

# 两种结果一样
print(d.__iter__()) # <dict_keyiterator object at 0x7fdf258b4a98>
print(iter(d))

"""
可迭代对象调用__iter__方法会变成迭代器对象(老母猪)

__iter__方法在调用的时候还有一个简便的写法iter()
    一般情况下所有的双下方法都会有一个与之对应的简化版本 方法名()
"""

3. 迭代器对象

  1. 迭代器对象:即含有__inter__方法,又含有__next__方法
  2. 可以让可迭代对象执行__iter__方法后就可以生成迭代器对象
  3. 迭代器对象无论执行多少次__iter__方法还是迭代器对象(本身)
  4. 迭代器提供了不依赖于索引取值的方式
# 通过变量名.__查看是否有next方法
i = 12
f = 11.11
s = 'jason'
l = [111,22,33,4]
d = {'username':'jason','pwd':123}  
t = (11,22,33)  
se = {11,22,33}  
b = True  
file = open(r'a.txt','w',encoding='utf8')


res = s.__iter__()  # 转成迭代器对象
print(res.__next__())  # 迭代器对象执行__next__方法其实就是在迭代取值(for循环) j
print(res.__next__())  # 在取完元素之后会报错

# 下面结果是一样的,每次生成新的迭代器对象再执行__next__方法
print(s.__iter__().__next__())  # j
print(s.__iter__().__next__())  # j

4. for循环本质

# 循环打印每个元素,不使用for循环
# __iter__和__next__
l1 = [1, 2, 3, 4, 5, 6, 7, 8, 9, 11, 22, 33, 44, 55]

# 将列表转为迭代器对象
res = l1.__iter__()
while True:
    print(res.__next__())  # 循环执行__next__取值,当取完元素之后会报错
    
    
for i in l1:
    print(i)
    
'''
for 循环内部原理
  1.将关键字in后面的数据先调用__iter__方法转为迭代器对象
  2.循环执行__next__方法
  3.在取完值后__next__会报错,但是for循环会自动捕获该错误并处理
'''

5. 异常捕获

# 什么是异常
	代码运行出错会导致异常 异常发生后如果没有解决方案则会到底整个程序结束
 
# 异常三个重要组成部分
	1.traceback:提示错误的行
  2.XXXError:错误的类型
  3.错误类型冒号后面的内容:错误的详细原因(仔细看可能就会找到解决的方法)

# 错误的种类   
    1.语法错误:不被允许的,出现了应该立刻修改!!!
    2.逻辑错误:可以被允许的,出现了之后尽快修改即可
   		'''修改逻辑错误的过程其实就是在从头到尾理清思路的过程'''
     
# 基本语法结构
    try:
        有可能会出错的代码
    except 错误类型 as e:
        出错之后对应的处理机制(e是错误的详细信息)
    except 错误类型 as e:
        出错之后对应的处理机制(e是错误的详细信息)
    except 错误类型 as e:
        出错之后对应的处理机制(e是错误的详细信息)

  eg:
  try:
      int('abc')
  except NameError as e:
      print('变量名name不存在',e)
  except ValueError:
      print('值不是纯数字')
      
# 捕获万能异常
  try:
      # int('abc')
      print(name)
      # l = [11]
      # l[100]
  except Exception:
      print('你来啥都行 无所谓')

"""
异常捕获句式和万能异常
    1.有可能会出现错误的代码才需要被监测
    2.被监测的代码一定要越少越好
    3.异常捕获使用频率越低越好
"""

# while 使用__next__方法抛出异常
l1 = [1, 2, 3, 4, 5, 6, 7, 8, 9, 11, 22, 33, 44, 55]
res = l1.__iter__()

try:
    while True:
        print(res.__next__())

except Exception:
    pass

标签:__,内置,迭代,python,iter,next,.__,print
来源: https://www.cnblogs.com/nineteenn/p/15578364.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有