前几天在学 Vue.js 的源码,发现数据的响应式很有意思,对数据进行修改能触发自定义的操作。所以我在想能否用这样的特性在 Python 上做个有意思的小工具。
然后我写了 Stora ,一个帮你保存字典数据到本地的 Python 库
GitHub - Stora: A simple, reactive local storage library
通过 Stora 保存数据非常简单,不需要手动操作文件 api 。你只需要更改字典中的数据,Stora 就会自动帮你保存到本地的文件。
保存的文件名默认为state.json,文件的存储路径默认为当前执行路径
安装
pip install stora 通过例子快速入门
from stora import stora apple = {"name": "Apple", "price": "10", "size": "small"} s = stora(apple) print(s.state) # {"name": "Apple", "price": "10", "size": "small"} PS: 你也可以自己决定文件名和路径,比如:
s = stora(apple, filename='apple.json', filepath='~/.data/')
现在你会发现执行目录中有一个state.json, 你会看到文件中内容已经被修改了。
{ "name": "Apple", "price": "10", "size": "small" } 下一次你在同一个路径下初始化一个 stora 对象,stora 将会搜索默认路径下有没有一个叫 state.json 的文件,如果有的话会尝试读取里面的数据并返回一个响应式的字典。
from stora import stora s = stora() print(s.state) # {"name": "Apple", "price": "10", "size": "small"} 取值和赋值操作是和字典一样的
# Fetching print(s.state['name']) # Apple print(s.state['price']) # 10 # Assignment s.state['name'] = 'Banana' s.state['price'] = 20 这时打开 state.json 会发现内容改变了
{ "name": "Banana", "price": "20", "size": "small" } 但是这里有个容易引起困惑的机制,如果已经有存储了数据的 state.json ,而你在初始化的时候再次对他赋值,返回的 stora 状态会是 state.json 中读取的数据,而非初始化的数据。
from stora import stora apple = {"name": "Apple", "price": "10", "size": "small"} s = stora(apple) print(s.state) # {"name": "Banana", "price": "20", "size": "small"} 这是为了防止数据丢失,所以已经存储在现有文件中的数据会有更高的优先级。
但你也可以通过强制重写来初始化 stora ,或者给 stora 一个不一样的文件名或路径
s1 = stora(apple, force=True) # 强制重写 s2 = stora(apple, filename='apple-10.json') # 定义不一样的文件名或路径 