百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

你别不信,这些python中的隐藏功能你能用过几个?

itomcoil 2025-06-09 22:37 5 浏览

“ 解锁Python的隐藏魔法,让你的代码更高效!”

相信你应该开发过不少python程序,也掌握了许多技巧,但还是有一些隐藏功能你可能没用过,你不信?接着往下看。

这篇文章主要探讨一些python中的隐藏功能,开启你的新探索之路。

01

节省内存的黑科技——__slots__

在面向对象开发为主的python中,一个类的创建那是信手拈来,相当方便,使用class即可创建一个类:

class Person:
    def __init__(self):
        self.name = '小明'
        self.age = 12

这是我们最常用的方法,它默认是使用字典的形式存储属性的,每个类都有它的__dict__方法,虽然灵活,但带来了额外开销,接下来请出__slots__来进行一次优化,有请:

class Person:
    __slots__ = ['name', 'age']


    def __init__(self):
        self.name = '小明'
        self.age = 12

很简单,仅需要申明出需要公开的属性名称,即可实现优化。但这也带来了一个缺点

未使用__slots__声明的属性如果存在或调用,将会报错:

class Person:
    __slots__ = ['name', 'age']


    def __init__(self):
        self.name = '小明'
        self.age = 12
        self.sex = 0


p = Person()
print(p.sex)

报错:AttributeError: 'Person' object has no attribute 'sex'

接下来我们比对一下使用__slots__前后对象的大小变化:

正常Persion对象大小

__slots__优化后Person对象大小

376字节

160字节

效果非常明显,直接内存下降50%,非常推荐使用。


02

加速递归的利器——functools.lru_cache

递归函数是开发中经常使用的一种函数方法,很多时候它的性能优化是整个程序中的重点突击部分,只要能把它优化好了,性能优化就好了大半了。

functools.lru_cache是一个装饰器,这就表示如果想要进行优化提升,仅仅需要在函数名称上方添加装饰器即可完成蜕变。

functools.lru_cache的原理是缓存,它通过缓存输出结果,避免重复计算来完成提优。

接下来我们来测试斐波那契数列其特点是每一个数字都是前两个数字的和,通常从前两项0和1开始。

def fibonacci(n):
    if n <= 1:
        return n
    else:
        return fibonacci(n - 1) + fibonacci(n - 2)
        
print(fibonacci(40)) # 花费21秒

可以看到我们仅40次递归就需要花费21秒,然后添加lru_cache的装饰器再试一次:

from functools import lru_cache


@lru_cache
def fibonacci(n):
    if n <= 1:
        return n
    else:
        return fibonacci(n - 1) + fibonacci(n - 2)
 
 print(fibonacci(40)) # 花费0.0000001秒

两次对比结果是:

正常递归调用

lru_cache优化后递归调用

21秒

0.0000001秒


可以看到这个前后对比非常之明显,推荐,推荐。


03

简化上下文管理——contextmanager

你是否经常使用with来优化代码?你是否厌倦了写__enter____exit__?那么contextmanager就是你的菜。首先我们看最原始的写法:

class TimeDiff:
    def __init__(self):
        self.start = None
        self.end = None


    def __enter__(self):
        self.start = time.time()


    def __exit__(self, exc_type, exc_val, exc_tb):
        self.end = time.time()


        print(f'共花费{self.end - self.start}秒')


with TimeDiff():
    total = 0
    for i in range(100):
        total += i

这是一个用来判断运行时间的类,可以看到如果用正常写法是比较冗长的,接下来看看contextmanager来如何优化:

from contextlib import contextmanager


@contextmanager
def time_diff():
    start = time.time()
    try:
        yield
    finally:
        end = time.time()
        print(f'共花费{end - start}秒')
        
with time_diff():
    total = 0
    for i in range(100):
        total += i

仅需要通过contextmanager装饰器来构造我们的方法,即可实现with功能,非常好用,推荐。


04

enumerate的隐藏参数——start

循环是一个非常实用的方法,很多同学也经常使用enumerate来进行循环,但你可能不知道enumerate有一个start参数可以自定义索引的开始下标,比如以下做法:

fruits = ['apple', 'banner', 'peach', 'pineapple']
for i, f in enumerate(fruits, start=2):
    print(f'{i}: {f}')

输出结果是:

2: apple
3: banner
4: peach
5: pineapple

可以看到,原来的下标从0开始,现在变为了从2开始。

这个方法按实际情况来使用,虽然不是实用方法,但可能在一些场景下能带来不错的代码优化效果。


05

字典操作小妙招——setdefault

我们经常有过这样的场景,通过字典来计算某些内容的个数来进行判断或者处理一些事物。比如我想要计算一串数据中男性和女性的个数:

students = [{'name': '小明', 'sex': 0}, {'name': '小红', 'sex': 1}, {'name': '小黑', 'sex': 1}, {'name': '大力', 'sex': 1}]


count_dict = {}
for stu in students:
    sex = stu.get('sex')
    if sex not in count_dict:
        count_dict[sex] = 0


    count_dict[sex] += 1


print(count_dict) # {0: 1, 1: 3}

sex表示男女,其中0为男,1为女,我们一般会通过以上形式来编写代码。这样的代码多了会产生疲惫感,因此可以通过setdefault来简化这样的代码:

students = [{'name': '小明', 'sex': 0}, {'name': '小红', 'sex': 1}, {'name': '小黑', 'sex': 1}, {'name': '大力', 'sex': 1}]


count_dict = {}
for stu in students:
    sex = stu.get('sex')
    count_dict.setdefault(sex, 0)
    count_dict[sex] += 1
 
print(count_dict) # {0: 1, 1: 3}

正如字面意思,setdefault会通过判断相应键是否存在来添加默认值,例如sex键如果不存在,则设其为0,如果存在则保持不变。

结尾


这些Python冷知识,你用过几个?快来评论区分享你的发现吧!

如果你还知道其他隐藏功能,欢迎留言告诉我!

相关推荐

信创系统下的Anaconda离线配置全攻略

原文链接:「链接」Hello,大家好啊,今天给大家带来一篇信创操作系统上离线配置Anaconda的文章,欢迎大家分享点赞,点个在看和关注吧!在信创环境下使用Anaconda对Python进行包...

【Python】Mac中Anaconda安装与使用(2025)

一、anaconda介绍我是一个多年的Java工程师,之前也写过一些简单的Python程序,随着AI的发展,后续使用Python会越来越多,和Java一样,Python涉及环境配置...

在豆包的协助下,折腾了一天,电脑盲终于把Doccano安装好了

折腾了一天,终于把Doccano软件装好了。先是用Deepseek,提示词:给新手小白出一个在新电脑上安装doccano的教程新手小白安装Doccano终极教程无需编程基础,两种方法任选,全程避坑...

用Python开发日常小软件,让生活与工作更高效!附实例代码

引言:Python如何让生活更轻松?在数字化时代,编程早已不是程序员的专属技能。Python凭借其简洁易学的特点,成为普通人提升效率、解决日常问题的得力工具。无论是自动化重复任务、处理数据,还是开发个...

用python怎么做最简单的桌面计算器

有网友问,用python怎么做一个最简单的桌面计算器。如果只强调简单,在本机运行,不考虑安全性和容错等的话,你能想到的最简单的方案是什么呢?我觉得用tkinter加eval就够简单的。现在开整。首先创...

用python操作excel、word、pdf非常迅速方便,迅速教会你

你会用python操作excel、word、pdf吗?不会也没关系,这篇文章教会你~【文末领取】案例篇幅有限,给大家准备了电子版PDF获取方式:...

10 个每个初学者都应该知道的 Python 技巧

1.无需临时变量交换两个变量的值之前:a=5b=10temp=aa=bb=temp之后:a,b=5,10a,b=b,aprint(a,b)#输出:1051...

SQL用了两年多,分享2个最常用的小技巧

导读:SQL是所有数据从业者必须打牢的基本功之一,扎实的SQL查询和适当的调优技巧是检验SQL能力的两大重要准则。个人曾经专门花费过好多时间用于提升SQL能力,期间也刷了大量的SQL题目,在这期间也...

Python 高手的 15 个代码技巧,让你的编程效率翻倍

在Python编程的世界里,我们总能遇到一些代码写得更短、更快、更整洁的开发者。他们似乎掌握了一些不为人知的秘密。本文将揭示15个实用的Python技巧,这些技巧在初学者教程中鲜有提及,却...

30天学会Python编程:16. Python常用标准库使用教程

16.1collections模块16.1.1高级数据结构16.1.2示例fromcollectionsimportdefaultdict,Counter,deque#默认字典...

7 个小 Python 技巧(python技巧总结60)

1.使用_作为临时变量这一点很微小,但非常强大。有时候你需要一个循环或一个你实际上不会使用的值。比如:for_inrange(3):print("Hello")过去...

如何系统的学python?(如何系统的学剪辑)

我不喜欢一上来就推荐一堆参考资料的东西,那只会让初学者更迷茫。好比一个婴儿,你告诉他学会走路的方法有100种,他只会变的对走路毫无兴趣,他要的只是一种最有效的学会走路的办法,而不是100种。同样的,下...

Python 静态方法、类方法与多态方法:特性解析与实战应用

在Python面向对象编程的重要概念,它们各自具备独特的特性和应用场景,为开发者提供了多样化的编程方式。静态方法不依赖实例状态,类方法以类为操作主体,多态方法则实现了不同类对象对同一消息的差异化响...

用 Python 库 PySimpleGUI 制作自动化办公小软件

Python在运维和办公自动化中扮演着重要的角色,PySimpleGUI是一款很棒的自动化辅助模块,让你更轻松的实现日常任务的自动化。1PySimpleGUI安装在命令行/终端输入:pipin...

一日多技:8个有趣的Python实用技巧

在这一小节中,我们将看到8个实用的python技巧,这些技巧使用比较高频且有用。列表的反向查找:我们可以使用reverse()函数让列表中的元素反向,它处理列表中存在的数字和字符串数据类型。下面我们直...