经验丰富程序员才知道的8种高级Python技巧


Posted in Python onJuly 27, 2020

本文将介绍8个简洁的Python技巧,若非经验十足的程序员,你肯定有些从未见过。向着更简洁更高效,出发吧!

经验丰富程序员才知道的8种高级Python技巧

1.通过多个键值将对象进行排序

假设要对以下字典列表进行排序:

people = [ 
{ 'name': 'John', "age": 64 }, 
{ 'name': 'Janet', "age": 34 }, 
{ 'name': 'Ed', "age": 24 }, 
{ 'name': 'Sara', "age": 64 }, 
{ 'name': 'John', "age": 32 }, 
{ 'name': 'Jane', "age": 34 }, 
{ 'name': 'John', "age": 99 }, 
]

不仅要按名字或年龄对其进行排序,还要将两个字段同时进行排序。在SQL中,会是这样的查询:

SELECT * FROM people ORDER by name, age

实际上,这个问题的解决方法可以非常简单,Python保证sort函数提供了稳定的排序顺序,这也意味着比较相似的项将保留其原始顺序。要实现按名字和年龄排序,可以这样做:

import operator 
people.sort(key=operator.itemgetter('age')) 
people.sort(key=operator.itemgetter('name'))

要注意如何反转顺序。首先按年龄分类,然后按名字分类,使用operator.itemgetter()从列表中的每个字典中获取年龄和名字字段,这样你就会得到想要的结果:

[ 
{'name': 'Ed', 'age': 24}, 
{'name': 'Jane', 'age': 34}, 
{'name': 'Janet','age': 34}, 
{'name': 'John', 'age': 32}, 
{'name': 'John', 'age': 64}, 
{'name': 'John', 'age': 99}, 
{'name': 'Sara', 'age': 64} 
]

名字是主要排序项,如果姓名相同,则以年龄排序。因此,所有John都按年龄分组在一起。

2.数据类别

自3.7版之后,Python开始能提供数据类别。比起常规类或其他替代方法(如返回多个值或字典),它有着更多优点:

  • 数据类需要很少的代码
  • 可以比较数据类,因为 __eq__ 可以实现此功能
  • 数据类需要类型提示,减少了发生错误的可能性
  • 可以轻松打印数据类以进行调试,因为__repr__可以实现此功能

这是一个工作中的数据类示例:

from dataclasses import dataclass 
     @dataclass 
     classCard: 
      rank: str 
      suit: str 
      card=Card("Q", "hearts") 
     print(card == card) 
     # True 
     print(card.rank) 
     # 'Q' 
     print(card) 
     Card(rank='Q', suit='hearts')

3.列表推导

列表推导可以在列表填写里代替讨厌的循环,其基本语法为

[ expression for item in list if conditional ]

来看一个非常基本的示例,用数字序列填充列表:

mylist = [i for i inrange(10)] 
    print(mylist) 
    # [0, 1, 2, 3,4, 5, 6, 7, 8, 9]

因为可以使用表达式,所以你还可以进行一些数学运算:

squares = [x**2for x inrange(10)] 
    print(squares) 
    # [0, 1, 4, 9,16, 25, 36, 49, 64, 81]

甚至能调用外部函数:

defsome_function(a): 
        return (a +5) /2 
        
       my_formula= [some_function(i) for i inrange(10)] 
       print(my_formula) 
       # [2.5, 3.0,3.5, 4.0, 4.5, 5.0, 5.5, 6.0, 6.5, 7.0]

最后,可以使用if函数来筛选列表。在这种情况下,只保留可被2除的值:

filtered = [i for i inrange(20) if i%2==0] 
    print(filtered) 
    # [0, 2, 4, 6,8, 10, 12, 14, 16, 18]

4.检查对象的内存使用情况

使用sys.getsizeof()可以检查对象的内存使用情况:

import sys 
     mylist =range(0, 10000) 
   print(sys.getsizeof(mylist)) 
   # 48

为什么这个庞大的列表只有48个字节?这是因为range函数返回的类表现为列表。与使用实际的数字列表相比,数序列的存储效率要高得多。我们可以通过列表推导来创建相同范围内的实际数字列表:

import sys 
     myreallist = [x for x inrange(0, 10000)] 
   print(sys.getsizeof(myreallist)) 
   # 87632

通过使用sys.getsizeof(),我们可以了解更多关于Python和内存使用情况的信息。

5.查找最频繁出现的值

要查找列表或字符串中最频繁出现的值:

test = [1, 2, 3, 4, 2, 2, 3, 1, 4, 4, 4] 
  print(max(set(test), key = test.count)) 
  # 4
  • max()将返回列表中的最大值。key参数采用单个参数函数自定义排序顺序,在本例中为test.count,该函数适用于迭代器上的每个项目。
  • test.count是list的内置功能。它接受一个参数,并计算该参数的出现次数。因此test.count(1)将返回2,而test.count(4)将返回4。
  • set(test)返回test中的所有唯一值,所以{1、2、3、4}

那么在这一行代码将接受test的所有唯一值,即{1、2、3、4}。接下来,max将对其应用list.count 函数并返回最大值。

还有一种更有效的方法:

from collections import Counter 
Counter(test).most_common(1) 
# [4: 4]

6.属性包

你可以使用attrs代替数据类,选择attrs有两个原因:

  • 使用的Python版本高于3.7
  • 想要更多功能

Theattrs软件包支持所有主流Python版本,包括CPython 2.7和PyPy。一些attrs可以提供验证器和转换器这种超常规数据类。来看一些示例代码:

@attrs 
   classPerson(object): 
    name =attrib(default='John') 
    surname =attrib(default='Doe') 
    age =attrib(init=False) 
    p =Person() 
   print(p) 
   p=Person('Bill', 'Gates') 
   p.age=60 
   print(p) 
     # Output: 
   # Person(name='John', surname='Doe',age=NOTHING) 
   # Person(name='Bill', surname='Gates', age=60)

实际上,attrs的作者已经在使用引入数据类的PEP了。数据类被有意地保持得更简单、更容易理解,而attrs 提供了可能需要的所有特性。

7.合并字典(Python3.5+)

dict1 = { 'a': 1, 'b': 2 } 
  dict2= { 'b': 3, 'c': 4 } 
  merged= { **dict1, **dict2 } 
  print (merged) 
  # {'a': 1, 'b':3, 'c': 4}

如果有重叠的键,第一个字典中的键将被覆盖。在Python 3.9中,合并字典变得更加简洁。上面Python 3.9中的合并可以重写为:

merged = dict1 | dict2

 8.返回多个值

Python中的函数在没有字典,列表和类的情况下可以返回多个变量,它的工作方式如下:

defget_user(id): 
      # fetch user from database 
      # .... 
      return name, birthdate 
     name, birthdate =get_user(4)

这是有限的返回值,但任何超过3个值的内容都应放入一个(数据)类。

这8个小技巧足够你好好消化一阵儿啦!

到此这篇关于经验丰富程序员才知道的8种高级Python技巧的文章就介绍到这了,更多相关程序员必知Python技巧内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
用Python创建声明性迷你语言的教程
Apr 13 Python
Python:Scrapy框架中Item Pipeline组件使用详解
Dec 27 Python
python实现定时自动备份文件到其他主机的实例代码
Feb 23 Python
Python实现微信消息防撤回功能的实例代码
Apr 29 Python
图文详解python安装Scrapy框架步骤
May 20 Python
pytorch 模型可视化的例子
Aug 17 Python
Python抓新型冠状病毒肺炎疫情数据并绘制全国疫情分布的代码实例
Feb 05 Python
Python itertools.product方法代码实例
Mar 27 Python
Python3创建Django项目的几种方法(3种)
Jun 03 Python
基于python代码批量处理图片resize
Jun 04 Python
python如何随机生成高强度密码
Aug 19 Python
pytorch 6 batch_train 批训练操作
May 28 Python
在 Windows 下搭建高效的 django 开发环境的详细教程
Jul 27 #Python
基于python实现MQTT发布订阅过程原理解析
Jul 27 #Python
Windows 平台做 Python 开发的最佳组合(推荐)
Jul 27 #Python
Python性能分析工具py-spy原理用法解析
Jul 27 #Python
python下载的库包存放路径
Jul 27 #Python
Python基础教程之输入输出和运算符
Jul 26 #Python
使用python求斐波那契数列中第n个数的值示例代码
Jul 26 #Python
You might like
PHP 配置文件中open_basedir选项作用
2009/07/19 PHP
CodeIgniter框架过滤HTML危险代码
2014/06/12 PHP
Linux下手动编译安装PHP扩展的例子分享
2014/07/15 PHP
SWFObject 2.1以上版本语法介绍
2010/07/10 Javascript
fancybox modal的完美解决(右上的X)
2012/10/30 Javascript
基于jQuery实现模拟页面加载进度条
2013/04/01 Javascript
js封装可使用的构造函数继承用法分析
2015/01/28 Javascript
JS判断网页广告是否被浏览器拦截过滤的代码
2015/04/05 Javascript
Three.js开发实现3D地图的实践过程总结
2017/11/20 Javascript
利用node实现一个批量重命名文件的函数
2017/12/21 Javascript
原生js实现照片墙效果
2020/10/13 Javascript
python安装以及IDE的配置教程
2015/04/29 Python
Python Paramiko模块的使用实际案例
2018/02/01 Python
Python爬虫解析网页的4种方式实例及原理解析
2019/12/30 Python
Python实现七个基本算法的实例代码
2020/10/08 Python
Django限制API访问频率常用方法解析
2020/10/12 Python
详解Python中的文件操作
2021/01/14 Python
Python机器学习工具scikit-learn的使用笔记
2021/01/28 Python
美国用餐电影院:Alamo Drafthouse Cinema
2020/01/23 全球购物
C#里面如何倒序排列一个数组的元素?
2013/06/21 面试题
开业庆典邀请函
2014/01/08 职场文书
公司活动邀请函
2014/01/24 职场文书
cf收人广告词大全
2014/03/14 职场文书
经济职业学院毕业生自荐书
2014/03/17 职场文书
交通事故调解协议书
2014/04/16 职场文书
家庭教育的心得体会
2014/09/01 职场文书
就业协议书范本
2014/10/08 职场文书
红白喜事主持词
2015/07/06 职场文书
Python Numpy之linspace用法说明
2021/04/17 Python
django注册用邮箱发送验证码的实现
2021/04/18 Python
用 Python 元类的特性实现 ORM 框架
2021/05/19 Python
Mysql数据库按时间点恢复实战记录
2021/06/30 MySQL
实体类或对象序列化时,忽略为空属性的操作
2021/06/30 Java/Android
详解MySql中InnoDB存储引擎中的各种锁
2022/02/12 MySQL
日本十大血腥动漫,那些被禁播的动漫盘点
2022/03/21 日漫
nginx配置限速限流基于内置模块
2022/05/02 Servers