Python提升“技术逼格”的6个方法

我是bee君,已采330篇花蜜,既甜又香。

列表生成式和生成器

from numpy import randoma = random.random(10000)

lst = []for i in a:    lst.append(i * i)  # 不推荐做法

lst = [i * i for i in a]  # 使用列表生成式

gen = (i * i for i in a)  # 生成器更节省内存

2 字典推导式创建子集

a = {‘apple‘: 5.6, ‘orange‘: 4.7, ‘banana‘: 2.8}da = {key: value for key, value in a.items() if value > 4.0}print(da)  # {‘apple‘: 5.6, ‘orange‘: 4.7}

3 Key使用itemgetter多字段排序

from operator import itemgettera = [{‘date‘: ‘2019-12-15‘, ‘weather‘: ‘cloud‘},     {‘date‘: ‘2019-12-13‘, ‘weather‘: ‘sunny‘},     {‘date‘: ‘2019-12-14‘, ‘weather‘: ‘cloud‘}]

a.sort(key=itemgetter(‘weather‘, ‘date‘))print(a)# [{‘date‘: ‘2019-12-14‘, ‘weather‘: ‘cloud‘}, {‘date‘: ‘2019-12-15‘, ‘weather‘: ‘cloud‘}, {‘date‘: ‘2019-12-13‘, ‘weather‘: ‘sunny‘}]

4 Key使用itemgetter分组

from operator import itemgetterfrom itertools import groupbya.sort(key=itemgetter(‘weather‘, ‘date‘))  # 必须先排序再分组for k, items in groupby(a, key=itemgetter(‘weather‘)):    print(k)    for i in items:        print(i)

5 sum类聚合函数与生成器

Python中的聚合类函数sum,min,max第一个参数是iterable类型,一般使用方法如下:

a = [4,2,5,1]sum([i+1for i in a]) # 16

使用列表生成式[i+1 for i in a]创建一个长度与a一样的临时列表,这步完成后,再做sum聚合。

试想如果你的数组a长度是百万级,再创建一个这样的临时列表就很不划算,最好是一边算一边聚合,稍改动为如下:

a = [4,2,5,1]sum(i+1for i in a) # 16

此时i+1 for i in a(i+1 for i in a)的简写,得到一个生成器(generator)对象,如下所示:

In [8]:(i+1for i in a)OUT [8]:<generator object <genexpr> at 0x000002AC7FFA8CF0>

生成器每迭代一步吐出(yield)一个元素并计算和聚合后,进入下一次迭代,直到终点。

6 ChainMap逻辑上合并多个字典

dic1 = {‘x‘: 1, ‘y‘: 2 }dic2 = {‘y‘: 3, ‘z‘: 4 }merged = {**dic1, **dic2} # {‘x‘: 1, ‘y‘: 3, ‘z‘: 4}

修改merged[‘x‘]=10,dic1中的x不变

ChainMap 只在逻辑上合并,在内部创建了一个容纳这些字典的列表。

from collections import ChainMapmerged = ChainMap(dic1,dic2)print(merged)# ChainMap({‘x‘: 1, ‘y‘: 2}, {‘y‘: 3, ‘z‘: 4})

使用ChainMap合并字典,修改merged[‘x‘]=10,dic1中的x改变

原文地址:https://www.cnblogs.com/7758520lzy/p/12215203.html

时间: 2024-08-30 13:49:16

Python提升“技术逼格”的6个方法的相关文章

提升大数据数据分析性能的方法及技术(二)

上部分链接 致谢:因为我的文章之前是在word中写的,贴过来很多用mathtype编辑的公式无法贴过来,之前也没有经验. 参考http://www.cnblogs.com/haore147/p/3629895.html,一文完成公式的迁移. 同时,说一句,word中用mathtype写的公式用ALT+\可以转换成对应的latex语法公式. 5 数据流过滤技术 信息大爆炸时代的到来使得针对数据进行深层次的挖掘成为数据处理的核心任务[21].但是在上面已经提到了,源数据的来源和数据的组成格式都是各种

Atitit 项目管理 提升开发效率的项目流程方法模型 哑铃型 &#160;橄榄型 直板型

Atitit 项目管理 提升开发效率的项目流程方法模型 哑铃型  橄榄型 直板型 项目主体三个部分 ui界面,中间层,数据库 按照不同的比重可以分为一下三个模型  哑铃型  橄榄型 直板型 哑铃型 开发效率更高,性能反之 ,ui和数据库层比较大,中间的接口层比较薄弱 直板型 橄榄型,追求性能型..中间打,俩偷笑 从语言看ui 界面h5是dsl 4gl+js  3.5gl....数据库是sql ,dsl  4gl 语言代际比较高.带来更高的开发效率性... 作者:: 绰号:老哇的爪子claw of

Python爬取网页的三种方法

# Python爬取网页的三种方法之一:  使用urllib或者urllib2模块的getparam方法 import urllib fopen1 = urllib.urlopen('http://www.baidu.com').info() fopen2 = urllib2.urlopen('http://www.sina.com').info() print fopen1.getparam('charset') print fopen2.getparam('charset') #----有些

提升网速的路由器优化方法(UPnP、QoS、MTU、交换机模式、无线中继)

在上一篇<为什么房间的 Wi-Fi 信号这么差>中,猫哥从微波炉.相对论.人存原理出发,介绍了影响 Wi-Fi 信号强弱的几大因素,接下来猫哥再给大家介绍几种不用升级带宽套餐也能提升网速的路由器优化方法. 防蹭网 开启 UPnP QoS 与网络限速 设置正确的 MTU 值 使用路由器交换机模式 使用无线中继扩展 Wi-Fi 信号 1.防蹭网 这是最最首要的一条:确认没有陌生人在蹭网! 被蹭网意味着你的 Wi-Fi 密码被泄露(看看是不是不小心用万能钥匙把自家 Wi-Fi 共享出去了?),或者你

几个提升JSP应用程序效率的方法(转)

原文出处:http://www.3lian.com/edu/2010/11-28/3711.html# 本文介绍了几个调整JSP和servlet的一些非常实用的方法,它可使你的servlet和JSP页面响应更快,扩展性更强.而且在用户数增加的情况下,系统负载会呈现出平滑上长的趋势.我将通过一些实际例子和配置方法使得你的应用程序的性能有出人意料的提升.其中,某些调优技术是在你的编程工作中实现的,而另一些技术是与应用服务器的配置相关的.我们将详细地描述怎样通过调整servlet和JSP页面,来提高你

【python】禁止print输出换行的方法

print后用一个逗号结尾就可以禁止输出换行,例子如下 >>> i=0 >>> while i < 3: print i i+=1 0 1 2 禁止输出换行后效果如下: >>> i=0 >>> while i < 3: print i, i+=1 0 1 2 [python]禁止print输出换行的方法,布布扣,bubuko.com

数据库数据处理性能提升技术

数据库数据处理性能提升技术 Java程序员在用的大数据工具,MongoDB稳居第一!

python动态获取对象的属性和方法

http://blog.csdn.net/kenkywu/article/details/6822220首先通过一个例子来看一下本文中可能用到的对象和相关概念.01     #coding: UTF-802     import sys #  模块,sys指向这个模块对象03     import inspect04     def foo(): pass # 函数,foo指向这个函数对象05      06     class Cat(object): # 类,Cat指向这个类对象07    

Python类的__getitem__和__setitem__特殊方法

class testsetandget:    kk = {};      def __getitem__(self, key):          return self.kk[key];      def __setitem__(self, key, value):          self.kk[key] = value;a = testsetandget()a['first'] = 1print a['first']a.__setitem__('second', 2)print a._