前几天在学 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') # 定义不一样的文件名或路径
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.