问题

你需要在数据序列上执行聚集函数(比如 sum() , min() , max() ), 但是首先你需要先转换或者过滤数据

解决方案

一个非常优雅的方式去结合数据计算与转换就是使用一个生成器表达式参数

比如:

import os

files = os.listdir("testPackage")
print(files) # ['__init__.py', 'cookBook', 'secondPackage', 'cookBook.py'] 只会找testPackage 下面的一级文件夹及文件
if any(name.endswith('.py') for name in files):
print('There be python!') # There be python!
else:
print('Sorry, no python.') s = ('ACME', 50, 123.45)
print(','.join(str(x) for x in s)) # ACME,50,123.45

优点使用一个生成器表达式作为参数会比先创建一个临时列表更加高效和优雅(不需要两个括号),而不是这样做

举例一:

nums = [1, 2, 3, 4, 5]
s = sum([x * x for x in nums])
print(s) # # 最好的做法:
nums = [1, 2, 3, 4, 5]
s = sum(x * x for x in nums)
print(s) #

举例二

portfolio = [
{'name': 'GOOG', 'shares': 50},
{'name': 'YHOO', 'shares': 75},
{'name': 'AOL', 'shares': 20},
{'name': 'SCOX', 'shares': 65}
]
print((s['shares'] for s in portfolio)) # <generator object <genexpr> at 0x7fd797fb8af0> 是个生成器
min_shares = min(s['shares'] for s in portfolio)
print(min_shares) # # 也可以这么写
min_shares = min(portfolio, key=lambda d: d["shares"])
print(min_shares) # {'name': 'AOL', 'shares': 20}

  

最新文章

  1. 开发者最爱的Firebug停止更新和维护
  2. SQL:执行顺序
  3. WPF如何控制每个窗体确保只打开一次
  4. Jquery实现兼容各大浏览器的Enter回车切换输入焦点的方法
  5. sql:pivot unpivot
  6. hibernate多SessionFactory配置
  7. PHPExcel 学习笔记
  8. 第四篇:SQL
  9. DataTables选择行并删除(删除单行)
  10. .NET 下成熟开源的BPM产品四款推荐
  11. struts2对action中的方法进行输入校验(2)
  12. 响应的系统设置的事件——重写onConfigurationChanged响应系统设置更改
  13. html统计
  14. 953.Verifying an Alien Dictionary(Map)
  15. C++STL模板库适配器之stack容器
  16. Educational Codeforces Round 5F. Expensive Strings
  17. MyBaits全局配置文件的各项标签2
  18. 安装Linux系统
  19. Apache hadoop安装配置
  20. 绝对路径${pageContext.request.contextPath}用法及其与web.xml中Servlet的url-pattern匹配过程

热门文章

  1. 解决text-align: justify;浏览器、安卓手机不兼容问题
  2. MariaDB学习笔记(一)
  3. elasticsearch Java Client用户指南
  4. 小白struts2 札记
  5. 关于python全局变量
  6. linux IO模式以及select、poll、epoll详解
  7. PyTorch 计算机视觉的迁移学习教程代码详解 (TRANSFER LEARNING FOR COMPUTER VISION TUTORIAL )
  8. JavaSE---System类
  9. 【leetcode】1003. Check If Word Is Valid After Substitutions
  10. Halo(四)