编程 Python包用于缓存函数的返回结果,以便持久化并保存在本地

2024-11-18 10:34:48 +0800 CST views 821

Python包用于缓存函数的返回结果,以便持久化并保存在本地

这个Python包专门设计用于缓存函数的返回结果,以便将结果持久化并保存在本地。它能够基于函数的参数内容和代码变动来判定是否需要读取已有的缓存。适用于那些运行时间长、但结果不经常变化的函数。

如果有一个函数运行时间很长,但在参数不变的情况下结果保持一致,那么可以通过简单的缓存注解来提升效率,非常方便!

示例

假设我们有一个 add 函数,第一次运行需要4秒钟,后续有缓存后运行则瞬间完成:

import time
from cache_result import cache

@cache()
def add(a, b):
    time.sleep(4)
    return a + b

print("第一次运行需要花费4秒,再次运行只需要瞬间")
print(add(1, 2))

更多用法

1. 注意事项

需要在项目根目录创建一个 .projectroot 文件,用来标识项目根目录,这样缓存文件会统一创建在项目根目录中。

2. 分文件缓存

通过路径设置,可以将不同结果缓存到不同的文件夹中,并支持使用占位符。

缓存计算斐波那契数列的第n项,并通过占位符缓存到不同文件夹中:

import time
from cache_result import cache

@cache('cache/fib/{n}')
def fib(n):
    """计算斐波那契数列的第n项"""
    if n < 2:
        return n
    else:
        return fib(n-1) + fib(n-2)

if __name__ == '__main__':
    print("计算斐波那契数列花费时间:")
    start = time.time()
    print(fib(40))  # 第一次计算将花费一些时间
    print('Time: ', time.time()-start)

    print("如果cache中有缓存结果了,再次运行会非常快")
    print("删除cache中的内容即可重新执行函数")

3. 按时间缓存

如果需要按照时间使缓存失效,可以通过日期和时间来组织缓存文件,从而更高效地管理缓存。你可以自行控制完整的时间格式,例如下面的写法会将缓存维持一小时:

import time
from cache_result import cache

@cache("cache/{time:YYYY-MM-DD_HH}")
def add(a, b):
    time.sleep(4)
    return a + b

print("第一次运行需要花费4秒,在一个小时内再次运行只需瞬间")
print(add(1, 2))

4. 排除某些参数

如果某些输入参数不会影响输出结果,可以进行排除,这样即使这些参数改变,也不会导致重新计算缓存。例如下面代码中排除了 sleep 参数:

import time
from cache_result import cache

@cache("cache/{time:YYYY-MM-DD_HH}", exclude_args=['sleep'])
def add(a, b, sleep=4):
    time.sleep(sleep)
    return a + b

print("排除了sleep参数的影响,他的改变不会导致重新缓存")
print(add(1, 2))
print(add(1, 2, sleep=2))

5. 高级用法

缓存目录的层级方便用户管理,缓存文件生成后可以任意修改缓存目录的层级。例如,缓存目录原为 cache/a,可以直接改为 cache/b,然后将本地缓存文件从 a 复制到 b

更多信息

更多详细内容可以参考GitHub仓库:cache-result。如果有任何问题欢迎在仓库中留言交流。如果觉得这个工具好用,别忘了给个Star支持一下哦!

GitHub地址: cache-result

复制全文 生成海报 编程 Python 性能优化 缓存 开源

推荐文章

解决 PHP 中的 HTTP 请求超时问题
2024-11-19 09:10:35 +0800 CST
在Vue3中实现代码分割和懒加载
2024-11-17 06:18:00 +0800 CST
git使用笔记
2024-11-18 18:17:44 +0800 CST
html流光登陆页面
2024-11-18 15:36:18 +0800 CST
Vue 3 是如何实现更好的性能的?
2024-11-19 09:06:25 +0800 CST
html一些比较人使用的技巧和代码
2024-11-17 05:05:01 +0800 CST
mysql时间对比
2024-11-18 14:35:19 +0800 CST
Vue3中如何实现国际化(i18n)?
2024-11-19 06:35:21 +0800 CST
Vue3中如何进行性能优化?
2024-11-17 22:52:59 +0800 CST
虚拟DOM渲染器的内部机制
2024-11-19 06:49:23 +0800 CST
Vue3中的自定义指令有哪些变化?
2024-11-18 07:48:06 +0800 CST
pin.gl是基于WebRTC的屏幕共享工具
2024-11-19 06:38:05 +0800 CST
微信小程序热更新
2024-11-18 15:08:49 +0800 CST
程序员茄子在线接单