当前位置: 首页 > news >正文

Python缓存利器:cachetools库详解

Python缓存利器:cachetools库详解

    • 1. cachetools简介
    • 2. 安装
    • 3. 基本概念
      • 3.1 LRU Cache (Least Recently Used)
      • 3.2 TTL Cache (Time-To-Live)
      • 3.3 LFU Cache (Least Frequently Used)
    • 4. 使用示例
      • 4.1 使用LRU Cache
      • 4.2 使用TTL Cache
      • 4.3 使用LFU Cache
      • 4.4 缓存装饰器
    • 5. 进阶用法
      • 5.1 自定义键函数
      • 5.2 缓存统计
    • 6. 总结

在开发过程中,我们经常需要使用缓存来提高程序的性能。Python的cachetools库提供了一系列实用的缓存装饰器和缓存类,使得在Python中实现缓存变得简单而高效。本文将详细介绍cachetools库的基本概念和使用方法。

1. cachetools简介

cachetools是一个Python库,提供了各种内存缓存的实现。它可以用于函数结果缓存、对象缓存等场景,能够有效提升程序性能,减少重复计算。

主要特点:

  • 提供多种缓存策略(LRU, TTL, LFU等)
  • 支持缓存大小限制
  • 线程安全
  • 可用作装饰器,使用简单

2. 安装

使用pip安装cachetools:

pip install cachetools

3. 基本概念

3.1 LRU Cache (Least Recently Used)

LRU缓存会优先淘汰最近最少使用的项目。

3.2 TTL Cache (Time-To-Live)

TTL缓存中的项目在指定时间后过期。

3.3 LFU Cache (Least Frequently Used)

LFU缓存会优先淘汰使用频率最低的项目。

4. 使用示例

4.1 使用LRU Cache

from cachetools import LRUCache, cached# 创建一个最大容量为100的LRU缓存
@cached(cache=LRUCache(maxsize=100))
def fibonacci(n):if n < 2:return nreturn fibonacci(n-1) + fibonacci(n-2)# 使用缓存的函数
print(fibonacci(100))

4.2 使用TTL Cache

from cachetools import TTLCache, cached
import time# 创建一个最大容量为100,过期时间为10秒的TTL缓存
cache = TTLCache(maxsize=100, ttl=10)@cached(cache)
def get_data():print("Fetching data...")return "Data"# 第一次调用,会打印"Fetching data..."
print(get_data())# 立即再次调用,使用缓存,不会打印"Fetching data..."
print(get_data())# 等待11秒后调用,缓存已过期,会再次打印"Fetching data..."
time.sleep(11)
print(get_data())

4.3 使用LFU Cache

from cachetools import LFUCache# 创建一个最大容量为100的LFU缓存
cache = LFUCache(maxsize=100)# 添加项目到缓存
cache['key1'] = 'value1'
cache['key2'] = 'value2'# 访问缓存
print(cache['key1'])# 当缓存满时,最不常用的项目会被移除

4.4 缓存装饰器

cachetools提供了方便的缓存装饰器:

from cachetools import cached, TTLCache
import time# 使用TTL缓存装饰器
@cached(cache=TTLCache(maxsize=100, ttl=30))
def get_weather(city):print(f"Fetching weather for {city}")# 模拟API调用time.sleep(2)return f"Sunny in {city}"# 第一次调用,会打印"Fetching weather..."
print(get_weather("Beijing"))# 立即再次调用,使用缓存结果
print(get_weather("Beijing"))# 不同参数调用,不会使用缓存
print(get_weather("Shanghai"))

5. 进阶用法

5.1 自定义键函数

可以自定义缓存的键生成函数:

from cachetools import cached, LRUCachedef make_key(func, *args, **kwargs):# 自定义键生成逻辑return str(args) + str(kwargs)@cached(cache=LRUCache(maxsize=100), key=make_key)
def my_function(arg1, arg2):return arg1 + arg2print(my_function(1, 2))
print(my_function(1, 2))  # 使用缓存

5.2 缓存统计

一些缓存类提供了统计信息:

from cachetools import LRUCachecache = LRUCache(maxsize=100)# 添加一些项目
for i in range(150):cache[i] = i * iprint(f"缓存大小: {len(cache)}")
print(f"缓存命中次数: {cache.hits}")
print(f"缓存未命中次数: {cache.misses}")

6. 总结

cachetools库为Python提供了强大而灵活的缓存解决方案。通过使用不同类型的缓存和缓存装饰器,我们可以轻松地在程序中实现高效的缓存机制,从而提升程序性能。在处理耗时的计算、频繁的API调用或需要重复访问的数据时,cachetools是一个非常有用的工具。

http://www.lryc.cn/news/391753.html

相关文章:

  • 【Python实战因果推断】20_线性回归的不合理效果10
  • 在Ubuntu 16.04上安装和配置ownCloud的方法
  • Java | Leetcode Java题解之第213题打家劫舍II
  • 使用 ESP32 接收 MAX4466 模拟麦克风模块的数据,通过 DAC 转码成 PCM 格式,并通过 MQTT 发送给另一台设备,可以通过以下步骤实现。
  • SQL二次注入原理分析
  • 在线签约如何选择?2024年10款顶级app大比拼
  • gcc: warning: -Wunused-function;加了选项,为什么就不报警告呢?
  • 系统提示我未定义与 ‘double‘ 类型的输入参数相对应的函数 ‘finverse‘,如何解决?
  • 【电路笔记】-B类放大器
  • Ubuntu 22.04 安装中文字体
  • 「树莓派入门」树莓派进阶04-直流电机控制与PWM应用
  • 利用数据集,用机器学习模型对股市预测,聊聊看!
  • 015-GeoGebra基础篇-定点旋转物体、动态显示数值并显示运动轨迹
  • 2024年6月份找工作和面试总结
  • 同步时钟:北斗/GPS卫星、电信基站、NTP以太网校时方式的区别
  • 实现Java应用的快速开发与迭代
  • 利用redis数据库管理代理库爬取cosplay网站-cnblog
  • 数据仓库建模基础理论-01-为什么需要数据建模?
  • 中序遍历的两种实现——二叉树专题复习
  • python 基础综合应用——小开发
  • 算法金 | 我最常用的两个数据可视化软件,强烈推荐
  • 【机器学习实战】Baseline精读笔记
  • Redis 缓存问题及解决
  • RISC-V的历史与设计理念
  • 山西车间应用LP-LP-SCADA系统的好处有哪些
  • setjmp和longjmp函数使用
  • vue-org-tree搜索到对应项高亮展开
  • FullCalendar日历组件集成实战(17)
  • 【图像分割】mask2former:通用的图像分割模型详解
  • 【不锈钢酸退作业区退火炉用高温辐射计快速安装】