聊聊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 相关文章推荐
在GitHub Pages上使用Pelican搭建博客的教程
Apr 25 Python
探究Python多进程编程下线程之间变量的共享问题
May 05 Python
Django中URL视图函数的一些高级概念介绍
Jul 20 Python
利用python生成一个导出数据库的bat脚本文件的方法
Dec 30 Python
python模块之time模块(实例讲解)
Sep 13 Python
Python中GIL的使用详解
Oct 03 Python
24式加速你的Python(小结)
Jun 13 Python
Django的models中on_delete参数详解
Jul 16 Python
python中类的输出或类的实例输出为这种形式的原因
Aug 12 Python
在python里使用await关键字来等另外一个协程的实例
May 04 Python
详解Python 中的容器 collections
Aug 17 Python
详解python的变量缓存机制
Jan 24 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
业余方法DIY电子管FM收音机
2021/03/02 无线电
php下连接ftp实现文件的上传、下载、删除文件实例代码
2010/06/03 PHP
使用php shell命令合并图片的代码
2011/06/23 PHP
DISCUZ在win2003环境下 Unable to access ./include/common.inc.php in... 的问题终极解决方案
2011/11/21 PHP
php封装的连接Mysql类及用法分析
2015/12/10 PHP
PHP 中魔术常量的实例详解
2017/10/26 PHP
thinkphp5.0自定义验证规则使用方法
2017/11/16 PHP
php中文语义分析实现方法示例
2019/09/28 PHP
PHP实现通过二维数组键值获取一维键名操作示例
2019/10/11 PHP
ThinkPHP 5.1 跨域配置方法
2019/10/11 PHP
图片格式的JavaScript和CSS速查手册
2007/08/20 Javascript
js 优化次数过多的循环 考虑到性能问题
2011/03/05 Javascript
js实现幻灯片效果(基于jquery插件)
2013/11/05 Javascript
页面元素绑定jquery toggle后元素隐藏的解决方法
2014/03/27 Javascript
JavaScript的jQuery库中function的存在和参数问题
2015/08/13 Javascript
jquery实现的V字形显示效果代码
2015/10/27 Javascript
实例详解AngularJS实现无限级联动菜单
2016/01/15 Javascript
JS代码防止SQL注入的方法(超简单)
2016/04/12 Javascript
jQuery实现淡入淡出的模态框
2017/02/09 Javascript
JavaScript实现带有子菜单和控件的slider轮播图效果
2017/11/01 Javascript
Webpack path与publicPath的区别详解
2018/05/03 Javascript
JavaScript判断数组类型的方法
2019/10/23 Javascript
关于vue路由缓存清除在main.js中的设置
2019/11/06 Javascript
解决Echarts2竖直datazoom滑动后显示数据不全的问题
2020/07/20 Javascript
JavaScript 几种循环方式以及模块化的总结
2020/09/03 Javascript
Python列表和元组的定义与使用操作示例
2017/07/26 Python
基于Python实现下载网易音乐代码实例
2020/08/10 Python
Django用内置方法实现简单搜索功能的方法
2020/12/18 Python
佳能德国网上商店:Canon德国
2017/03/18 全球购物
xml有哪些解析技术?区别是什么
2016/04/26 面试题
优秀教师的感人事迹
2014/02/04 职场文书
蜜蜂引路教学反思
2014/02/04 职场文书
优秀本科生求职推荐信
2014/02/24 职场文书
不遵守课堂纪律的检讨书
2014/09/24 职场文书
实习介绍信范文
2015/05/05 职场文书
如何拟写通知正文?
2019/04/02 职场文书