聊聊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 相关文章推荐
利用Psyco提升Python运行速度
Dec 24 Python
对python中的pop函数和append函数详解
May 04 Python
python清除字符串中间空格的实例讲解
May 11 Python
Python拼接微信好友头像大图的实现方法
Aug 01 Python
Python3.5常见内置方法参数用法实例详解
Apr 29 Python
详解Python3网络爬虫(二):利用urllib.urlopen向有道翻译发送数据获得翻译结果
May 07 Python
python实现输入任意一个大写字母生成金字塔的示例
Oct 27 Python
django 简单实现登录验证给你
Nov 06 Python
Python concurrent.futures模块使用实例
Dec 24 Python
python传到前端的数据,双引号被转义的问题
Apr 03 Python
解决pycharm不能自动保存在远程linux中的问题
Feb 06 Python
django学习之ajax post传参的2种格式实例
May 14 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中检查文件或目录是否存在的代码小结
2012/10/22 PHP
基于HBase Thrift接口的一些使用问题及相关注意事项的详解
2013/06/03 PHP
深入PHP内存相关的功能特性详解
2013/06/08 PHP
PHP使用NuSOAP调用Web服务的方法
2015/07/18 PHP
php自定义类fsocket模拟post或get请求的方法
2015/07/31 PHP
PHP中类的自动加载的方法
2017/03/17 PHP
PHP5.6读写excel表格文件操作示例
2019/02/26 PHP
php文件上传原理与实现方法详解
2019/12/20 PHP
如何将JS的变量值传递给ASP变量
2012/12/10 Javascript
一个js控制的导航菜单实例代码
2013/12/03 Javascript
js实现仿网易点击弹出提示同时背景变暗效果
2015/08/13 Javascript
ES6新特性之解构、参数、模块和记号用法示例
2017/04/01 Javascript
jquery如何实现点击空白处隐藏元素
2017/12/05 jQuery
Vuex 入门教程
2018/01/10 Javascript
nodejs结合Socket.IO实现的即时通讯功能详解
2018/01/12 NodeJs
nodejs使用async模块同步执行的方法
2019/03/02 NodeJs
jQuery实现图片随机切换、抽奖功能(实例代码)
2019/10/23 jQuery
使用IronPython把Python脚本集成到.NET程序中的教程
2015/03/31 Python
Python中的map()函数和reduce()函数的用法
2015/04/27 Python
Python基于回溯法子集树模板解决全排列问题示例
2017/09/07 Python
python实现多层感知器MLP(基于双月数据集)
2019/01/18 Python
selenium跳过webdriver检测并模拟登录淘宝
2019/06/12 Python
Python argparse模块应用实例解析
2019/11/15 Python
python实现简单井字棋游戏
2020/03/04 Python
django中嵌套的try-except实例
2020/05/21 Python
10个python爬虫入门基础代码实例 + 1个简单的python爬虫完整实例
2020/12/16 Python
Python tkinter之Bind(绑定事件)的使用示例
2021/02/05 Python
CSS3制作炫酷的自定义发光文字
2016/03/28 HTML / CSS
html5 音乐播放器 audio 标签使用概述
2013/07/15 HTML / CSS
墨尔本复古时尚品牌:Dangerfield
2018/12/12 全球购物
师范大学毕业自我鉴定
2013/11/21 职场文书
11月升旗仪式讲话稿
2014/02/15 职场文书
亲子读书活动方案
2014/02/22 职场文书
地球物理学专业推荐信
2014/09/08 职场文书
生产工厂门卫岗位职责
2014/09/26 职场文书
2016大一新生入学教育心得体会
2016/01/23 职场文书