python中的queue.Queue()队列如何持久化存储?
即时程序中途退出重启,queue.Queu还能保存未消费的消息队列。
网友回复
我来介绍几种实现 Queue 持久化的方法:
使用 pickle 序列化存储(简单但不推荐用于生产环境):import queue import pickle import atexit class PersistentQueue: def __init__(self, filename="queue.pkl"): self.filename = filename # 尝试加载已存在的队列数据 try: with open(self.filename, 'rb') as f: self.queue = pickle.load(f) except FileNotFoundError: self.queue = queue.Queue() # 注册程序退出时的保存操作 atexit.register(self.save) def put(self, item): self.queue.put(item) self.save() # 每次放入数据后保存 def get(self): item = self.queue.get() self.save() # 每次获取数据后保存 return item def save(self): with open(self.filename, 'wb') as f: pickle.dump(self.queue, f)使用 SQLite 存储(推荐用于小型应用):
import sqlite3 import queue import json class SQLiteQueue: def __init__(self, db_path="queue.db"): self.conn = sqlite3.connect(db_path) self.cursor = self.conn.cursor() self.cursor.execute(''' CREATE ...
点击查看剩余70%
Playwright如何实现抖音头条自媒体浏览器中自动发布作品?
playwright如何获取网页dom树结构并触发dom操作比如粘贴?
playwright如何加载本地chrome浏览器的中网站的cookie数据?
python+playwright如何自主搜集整理新闻打开浏览器自主填写表单发布?
python+playwright如何实现大模型自主开发网页应用自主查看效果修改?
如何应对ai反混淆解密混淆加密后的js代码?
python如何判断大模型的输入tokens是否超过最大限制?
如何解决ai大模型的输入token超过最大值问题?
有没有不依赖大模型的pdf ocr内容识别markdown组件?
如何调用deepseek r1的api的时候只输出思考过程?