本文实例讲述了Python筛选及提取序列中元素的方法。分享给大家供大家参考,具体如下:
问题:提取出序列中的值或者根据某些标准对序列做删减
解决方案:列表推导式、生成器表达式、使用内建的filter()函数
1、列表推导式方法:存在一个潜在的缺点,如果输入数据非常大可能会产生一个庞大的结果,考虑到该问题,建议选择生成器表达式
# Examples of different ways to filter data mylist = [1, 4, -5, 10, -7, 2, 3, -1] print('mylist=',mylist) # 使用列表推导式 pos = [n for n in mylist if n > 0] print('正数为:',pos) neg = [n for n in mylist if n < 0] print('负数为:',neg)
运行结果:
mylist= [1, 4, -5, 10, -7, 2, 3, -1] 正数为: [1, 4, 10, 2, 3] 负数为: [-5, -7, -1]
2、生成器表达式方法:
mylist = [1, 4, -5, 10, -7, 2, 3, -1] print('mylist=',mylist) # 使用生成器表达式 pos = (n for n in mylist if n > 0) print('生成器为',pos) for x in pos: print(x)
运行结果:
mylist= [1, 4, -5, 10, -7, 2, 3, -1] 生成器为 <generator object <genexpr> at 0x02421FD0> 1 4 10 2 3
3、如果筛选标准无法简单表示在列表推导式或者生成器表达式中,比如筛选过程涉及一些异常处理或者更复杂的细节,可以考虑将处理筛选逻辑的代码放到单独的函数中,然后使用内建的filter()函数处理。
values=['1','2','-3','-','N/A','4','5','%'] def is_int(val): #将处理筛选逻辑的代码放到单独的函数 try: x=int(val) return True except ValueError: return False ivals=list(filter(is_int,values)) #使用filter(func,list)进行过滤 print(ivals)
运行结果:
['1', '2', '-3', '4', '5']
filter(func,list)会创建一个迭代器,如果想要列表形式的结果,需使用list()将结果转为列表。
补充:
用新值替换掉不满足标准的值,而不是丢弃它们,可通过将筛选条件移到一个条件表达式中来轻松实现。
# Negative values clipped to 0 neg_clip = [n if n > 0 else 0 for n in mylist] print('负数替换为0,结果:',neg_clip) # Positive values clipped to 0 pos_clip = [n if n < 0 else 0 for n in mylist] print('正数替换为0,结果:',pos_clip) '''
运行结果:
mylist= [1, 4, -5, 10, -7, 2, 3, -1] 负数替换为0,结果: [1, 4, 0, 10, 0, 2, 3, 0] 正数替换为0,结果: [0, 0, -5, 0, -7, 0, 0, -1]
值得推荐的工具itertools.compress(),它接受一个可迭代对象以及一个布尔选择器序列作为输入。
如果想把对一个序列的筛选结果施加到另一个相关的序列上时,就会非常有用。
# 采用筛选工具itertools.compress() addresses = [ '5412 N CLARK', '5148 N CLARK', '5800 E 58TH', '2122 N CLARK', '5645 N RAVENSWOOD', '1060 W ADDISON', '4801 N BROADWAY', '1039 W GRANVILLE', ] counts = [ 0, 3, 10, 4, 1, 7, 6, 1] from itertools import compress more5 = [ n > 5 for n in counts ] a = list(compress(addresses, more5)) print(a)
运行结果:
['5800 E 58TH', '1060 W ADDISON', '4801 N BROADWAY']
这里的关键是首先创建一个布尔序列,用来表示哪个元素可满足我们的条件。然后compress()函数挑选出满足布尔值为True的相应元素。
同filter()函数一样,正常情况下compress()函数返回一个迭代器,若需要返回列表则需使用list()将结果转为列表。
(代码摘自《Python Cookbook》)
更多关于Python相关内容感兴趣的读者可查看本站专题:《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》、《Python入门与进阶经典教程》及《Python文件与目录操作技巧汇总》
希望本文所述对大家Python程序设计有所帮助。
常见排序算法 稳定排序: 冒泡排序 — O(n²) 插入排序 — O(n²) 桶排序 — O(n); 需要 O(k) 额外空间 归并排序 — O(nlogn); 需要 O(n) 额外空间 二叉排序树排序 — O(n log n) 期望时间; O(n²)最坏时间; 需要 O(n) 额外空间 基数排序 — O(n·k); 需要 O(n) 额外空间 不稳定排序 选择排序 — O(n²) 希尔排序 — O
本文向大家介绍Python如何筛选序列中的元素的方法实现,包括了Python如何筛选序列中的元素的方法实现的使用技巧和注意事项,需要的朋友参考一下 本篇文章给大家带来的内容是关于Python如何筛选序列中的元素 ,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 1、需求 序列中含有一些数据,我们需要提取其中的值或根据某些标准对序列做删减, 2、解决方案 要筛选序列中的数据,通常最简
本文向大家介绍Python cookbook(数据结构与算法)找出序列中出现次数最多的元素算法示例,包括了Python cookbook(数据结构与算法)找出序列中出现次数最多的元素算法示例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Python找出序列中出现次数最多的元素。分享给大家供大家参考,具体如下: 问题:找出一个元素序列中出现次数最多的元素是什么 解决方案:collectio
排序算法的评价 稳定性 稳定排序算法会依照相等的关键(换言之就是值)维持纪录的相对次序。也就是一个排序算法是稳定的,就是当有两个有相等关键的纪录R和S,且在原本的串行中R出现在S之前,在排序过的串行中R也将会是在S之前。 计算复杂度(最差、平均、和最好表现) 依据串行(list)的大小(n),一般而言,好的表现是O(nlogn),且坏的行为是O(n2)。对于一个排序理想的表现是O(n)。仅使用一个
leetcode/lintcode上的算法题 关于问题的答案和解体的思路,可以移步 : https://github.com/zhaozhengcoder/Algorithm About 这个仓库最初的想法是把lintcode/lintocde上面的算法题目整理一下,因为很多题目太多了显得太乱了,就不继续在GitHub上面写了,以前写的一部分移到我的博客上面了。 GitHub上面打算整理一些比较典
栈(Stack) 是限定仅在 表尾 进行 插入和删除 操作的线性表。对前前端工程师来说日操作浏览后退前进 我们把允许插入和删除的一端为栈顶(top),另一端为栈底(bottom)。 栈又称为 后进先出 (Last In Firsot Out)的线性表,简称 LIFO 结构。 栈的实现 数组 - 顺序栈(内存地址连续性) 链表 - 链式栈 数组 - 顺序栈 用数组来一实现个栈 /** push(e