聊聊python中的循环遍历


Posted in Python onSeptember 07, 2020

python之循环遍历

关于循环遍历大家都知道,不外乎for和while,今天我在这写点不一样的循环和遍历。在实践中有时会遇到删除列表中的元素,那么循环遍历列表删除指定元素该怎么做呢?

还是直接上代码看案例吧:

import time

# 删除下面列表中所有张姓元素,输出的结果应该是['李老大','李老二']
lst = ['张老大', '张老二', '李老大', '张老三', '李老二']*10000

# 直接for循环遍历列表,remove需要删除的元素
def del1(lst):
  for i in lst:
    if i[0] == '张':
      lst.remove(i) # 在删lst[0]'张老大'的时候,列表长度变成4,导致lst[1]取值成了'李老大',跳过了'张老二'
  return lst # 返回的结果不符合预期


# 正向遍历,通过建一个原列表的副本,然后遍历副本,删除原列表中的元素
def del2(lst):
  lst2 = lst.copy() # 创建副本内存和时间开销大
  for i in lst2:
    if i[0] == '张':
      lst.remove(i) # 删除第一个匹配的元素,检索匹配时间开销大
  return lst # 结果虽然正确,但效率极低,不要用这种方法


# 使用高阶函数filter方法
def del3(lst):
  def comp(n): # 创建过滤函数
    return n[0] != '张' #对于首字符不是'张'的元素返回True,予以保留。若返回False的予以删除。
  return list(filter(comp, lst)) # filter高阶函数删除列表中的元素,
# 删除条件是comp方法,返回的是迭代器,需要list方法转成列表


# 倒序删除法
def del4(lst):
  for i in range(len(lst) - 1, -1, -1): # 注意len(lst)必须-1,因为列表元素下标是0至len(lst)-1;注意for循环左开右闭,
# 从lst队尾循环到开头必须是-1,写0会漏了lst[0];-1表示倒序排列。range实际就是int数字列表生成式,在这实际生成的是
# [49999,49998,..1,0],通过下标访问列表的指定元素。
    if lst[i][0] == '张':
      del lst[i]
  return lst


# 倒序删除之while循环,效果和for序号一致,运行效率差别极其微小(for序号方法内存开销略大一点点)。while循环需要写7行,
# for循环只要5行,更推荐使用for循环。但while循环代码阅读起来更易懂。
def del5(lst):
  length = len(lst) - 1
  while length >= 0:
    if lst[length][0] == '张':
      del lst[length]
    length -= 1
  return lst


# lst = del1(lst) # del1方法直接遍历列表删除指定元素,返回结果错误
# print(lst)

# t1 = time.time()
# lst = del2(lst) # del2方法通过创建原列表副本,遍历副本删除原件中的指定元素,返回结果正确,但是运行效率极低
# t2 = time.time()
# print(f"遍历方法删除元素用时:{t2 - t1:.5f}") # 4.51529,在这可以看到代码优化的必要性,运行结果虽然一致但性能差别极大。
# 评价性能一般看2个指标,1是时间消耗,2是资源消耗(通常指内存消耗,特殊场合还有别的资源消耗)。

t1 = time.time()
lst = del3(lst)
t2 = time.time()
print(f"filter方法删除元素用时:{t2 - t1:.5f}") # 0.00596

# t1 = time.time()
# lst = del4(lst)
# t2 = time.time()
# print(f"遍历方法删除元素用时:{t2 - t1:.5f}") # 0.07991

# t1 = time.time()
# lst = del5(lst)
# t2 = time.time()
# print(f"遍历方法删除元素用时:{t2 - t1:.5f}") # 0.08516

以上案例注释非常详细,初学者可以阅读参考。其中del4()for循环和del5()while循环时间消耗几乎一致,for循环内存消耗略大一点点。for循环可以比while循环少写2行代码,学python用python在同样性能指标下自然是代码行数越少越好,写循环优先考虑for。

另外提一句,使用filter高阶函数运行速度是for或while的13-15倍,因为filter实际执行的是c代码。在python中有很多内置方法实际是c代码,用好了会大大提高运行效率。虽然python是公认的开发效率高运行效率低,但是只要针对运算量极大的循环执行代码块进行恰当优化(通常就是使用这种c代码的内置方法,有能力的也可以自定义c代码方法,或者是第三方的c代码方法),python性能并不弱多少,而开发效率提升很多,所以python会这么流行。

以上就是聊聊python中的循环遍历的详细内容,更多关于python 循环遍历的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
低版本中Python除法运算小技巧
Apr 05 Python
浅析Python中的序列化存储的方法
Apr 28 Python
简单介绍Python中的floor()方法
May 15 Python
Python3 加密(hashlib和hmac)模块的实现
Nov 23 Python
Python排序搜索基本算法之希尔排序实例分析
Dec 09 Python
Python 记录日志的灵活性和可配置性介绍
Feb 27 Python
DRF跨域后端解决之django-cors-headers的使用
Jan 27 Python
django模板结构优化的方法
Feb 28 Python
为什么是 Python -m
Jun 19 Python
python实战之90行代码写个猜数字游戏
Apr 22 Python
python实现简单的聊天小程序
Jul 07 Python
python如何查找列表中元素的位置
May 30 Python
详解python中的闭包
Sep 07 #Python
python logging模块的使用
Sep 07 #Python
了解一下python内建模块collections
Sep 07 #Python
Python pymsql模块的使用
Sep 07 #Python
Python虚拟环境的创建和使用详解
Sep 07 #Python
python用Tkinter做自己的中文代码编辑器
Sep 07 #Python
利用Python将图片中扭曲矩形的复原
Sep 07 #Python
You might like
PHP根据传入参数合并多个JS和CSS文件的简单实现
2014/06/13 PHP
PHPUnit测试私有属性和方法功能示例
2018/06/12 PHP
Mootools 1.2教程 输入过滤第一部分(数字)
2009/09/15 Javascript
JS获取各种浏览器窗口大小的方法
2014/01/14 Javascript
jQuery实现的一个自定义Placeholder属性插件
2014/08/11 Javascript
Nodejs实现多人同时在线移动鼠标的小游戏分享
2014/12/06 NodeJs
jquery.form.js实现将form提交转为ajax方式提交的方法
2015/04/07 Javascript
jQuery处理图片加载失败的常用方法
2015/06/08 Javascript
JS+CSS实现带小三角指引的滑动门效果
2015/09/22 Javascript
JS实现漂亮的淡蓝色滑动门效果代码
2015/09/23 Javascript
JavaScript中eval函数的问题
2016/01/31 Javascript
AJAX实现瀑布流触发分页与分页触发瀑布流的方法
2016/05/23 Javascript
vue ssr 指南详读
2018/06/29 Javascript
Typescript 中的 interface 和 type 到底有什么区别详解
2019/06/18 Javascript
Vue.js+cube-ui(Scroll组件)实现类似头条效果的横向滚动导航条
2019/06/24 Javascript
基于Vue SEO的四种方案(小结)
2019/07/01 Javascript
jQuery操作选中select下拉框的值代码实例
2020/02/07 jQuery
JavaScript装饰者模式原理与用法实例详解
2020/03/09 Javascript
jquery实现简单自动轮播图效果
2020/07/29 jQuery
nuxt.js服务端渲染中axios和proxy代理的配置操作
2020/11/06 Javascript
[47:03]完美世界DOTA2联赛PWL S3 access vs LBZS 第一场 12.20
2020/12/23 DOTA
python实现汉诺塔方法汇总
2016/07/25 Python
Centos 升级到python3后pip 无法使用的解决方法
2018/06/12 Python
Django框架中序列化和反序列化的例子
2019/08/06 Python
python fuzzywuzzy模块模糊字符串匹配详细用法
2019/08/29 Python
Python pandas 列转行操作详解(类似hive中explode方法)
2020/05/18 Python
简单说下OSPF的操作过程
2014/08/13 面试题
水产养殖学应届生求职信
2013/09/29 职场文书
大四本科生的自我评价
2013/12/30 职场文书
高三霸气励志标语
2014/06/24 职场文书
行政答辩状范文
2015/05/21 职场文书
电台广播稿范文
2015/08/19 职场文书
高中班主任工作总结(范文)
2019/08/20 职场文书
撤回我也能看到!教你用Python制作微信防撤回脚本
2021/06/11 Python
一文搞懂python异常处理、模块与包
2021/06/26 Python
关于k8s环境部署mysql主从的问题
2022/03/13 MySQL