Python cookbook(数据结构与算法)筛选及提取序列中元素的方法


Posted in Python onMarch 19, 2018

本文实例讲述了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单链表实现代码实例
Nov 21 Python
Python functools模块学习总结
May 09 Python
Python利用operator模块实现对象的多级排序详解
May 09 Python
解决Scrapy安装错误:Microsoft Visual C++ 14.0 is required...
Oct 01 Python
Python使用Selenium模块实现模拟浏览器抓取淘宝商品美食信息功能示例
Jul 18 Python
linux环境下Django的安装配置详解
Jul 22 Python
python tkinter基本属性详解
Sep 16 Python
python cv2截取不规则区域图片实例
Dec 21 Python
Django values()和value_list()的使用
Mar 31 Python
Selenium自动化测试工具使用方法汇总
Jun 12 Python
如何一键升级Python所有包
Nov 05 Python
Python如何让字典保持有序排列
Apr 29 Python
django用户注册、登录、注销和用户扩展的示例
Mar 19 #Python
Python cookbook(数据结构与算法)根据字段将记录分组操作示例
Mar 19 #Python
遗传算法python版
Mar 19 #Python
python实现简单遗传算法
Mar 19 #Python
python psutil库安装教程
Mar 19 #Python
Python递归实现汉诺塔算法示例
Mar 19 #Python
Python实现替换文件中指定内容的方法
Mar 19 #Python
You might like
PHP XML操作类DOMDocument
2009/12/16 PHP
深入浅出讲解:php的socket通信原理
2016/12/03 PHP
一些常用的Javascript函数
2006/12/22 Javascript
js修改table中Td的值(定义td的双击事件)
2013/01/10 Javascript
javascript面向对象包装类Class封装类库剖析
2013/01/24 Javascript
jquery解决图片路径不存在执行替换路径
2013/02/06 Javascript
JavaScript实现找出字符串中第一个不重复的字符
2014/09/03 Javascript
javascript trim函数在IE下不能用的解决方法
2014/09/12 Javascript
js事件绑定快捷键以ctrl+k为例
2014/09/30 Javascript
JavaScript缓冲运动实现方法(2则示例)
2016/01/08 Javascript
JavaScript  cookie 跨域访问之广告推广
2016/04/20 Javascript
深入分析javascript中的错误处理机制
2016/07/17 Javascript
react系列从零开始_简单谈谈react
2017/07/06 Javascript
基于input框覆盖掉数字英文的实例讲解
2017/07/21 Javascript
前端主流框架vue学习笔记第二篇
2017/07/26 Javascript
最通俗易懂的javascript变量提升详解
2017/08/05 Javascript
JavaScript 完成注册页面表单校验的实例
2017/08/19 Javascript
又拍云 Node.js 实现文件上传、删除功能
2018/10/28 Javascript
微信小程序 调用微信授权窗口相关问题解决
2019/07/25 Javascript
Vue的状态管理vuex使用方法详解
2020/02/05 Javascript
怎么理解wx.navigateTo的events参数使用详情
2020/05/18 Javascript
精读《Vue3.0 Function API》
2020/05/20 Javascript
原生js实现日期选择插件
2020/05/21 Javascript
解决VUE 在IE下出现ReferenceError: Promise未定义的问题
2020/11/07 Javascript
[02:22]2018DOTA2亚洲邀请赛VG赛前采访
2018/04/03 DOTA
将Python的Django框架与认证系统整合的方法
2015/07/24 Python
Python在图片中添加文字的两种方法
2017/04/29 Python
浅谈Tensorflow模型的保存与恢复加载
2018/04/26 Python
Django Sitemap 站点地图的实现方法
2019/04/29 Python
python调用matplotlib模块绘制柱状图
2019/10/18 Python
Python Dict找出value大于某值或key大于某值的所有项方式
2020/06/05 Python
opencv 图像礼帽和图像黑帽的实现
2020/07/07 Python
python将下载到本地m3u8视频合成MP4的代码详解
2020/11/24 Python
文秘人员工作职责
2014/01/31 职场文书
求职信内容怎么写
2014/05/26 职场文书
Python基础之元组与文件知识总结
2021/05/19 Python