一个关于设计的问题
我现在想做一个小玩意,涉及到存储问题,用数据库当然最好,不过项目实在是太小,而且用数据库使用也不方便,故此想使用纯文本文件来存储一、使用列表存储格式如下
[{zh:xxx,mac:xxx,bz:xxxx}{下同}{}{}........]
二、使用json(字典) 格式如下
{zh1:,zh2:.........}
关键点:zh mac这两项都不能重复 在新增(追加)数据时 如何校验这两项是否有存在项 是个问题
或者有更好的方案 给演示一下(数据库就不要了) 你的意思是 zh 和 mac 这两项所对应的值 不能 重复,对吗?
如果你会点pandas,可以考虑一下 用 df.zh.duplicated() 来判断, 用 df.drop_duplicated(subset=['zh', 'mac']) 来过滤掉重复的
用纯python判断,也不难,比如:
data=[{'zh': 1, 'mac': 2, 'bz': 3}, {'zh': 100, 'mac': 200, 'bz': 300}, {'zh': 50, 'mac': 60, 'bz': 70}, {'zh': 100, 'mac': 99, 'bz': 98}]
zh_values = [ d['zh'] for d in data ]
zh_values
def validate_dup(new_data):
zh_values = [ d['zh'] for d in data ]
mac_values = [ d['mac'] for d in data ]
if new_data['zh'] in zh_values:
print('zh项数据 已经存在相同的值!')
if new_data['mac'] in mac_values:
print('mac项数据 已经存在相同的值!')
validate_dup({'zh':666, 'mac':2, 'bz': 777})
mac项数据 已经存在相同的值!
validate_dup({'zh':1, 'mac':2, 'bz': 777})
zh项数据 已经存在相同的值!
mac项数据 已经存在相同的值! 阿奇_o 发表于 2022-9-4 21:25
你的意思是 zh 和 mac 这两项所对应的值 不能 重复,对吗?
如果你会点pandas,可以考虑一下 用 df.zh. ...
谢谢,我突然发现用py自带的sqlite似乎也可以, 阿奇_o 发表于 2022-9-4 21:25
你的意思是 zh 和 mac 这两项所对应的值 不能 重复,对吗?
如果你会点pandas,可以考虑一下 用 df.zh. ...
你的意思是 把所有数据排列成一个二维表就像EXCEL似的然后用pandas 来做吗 抽象一个类吧
# coding: utf-8
import json
import os
class ConfigController:
"""配置控制器"""
def __init__(self, path):
"""path 为配置文件的路径,不存在则创建,存在则载入"""
self.__path = path
self.__config = dict()
self.__loadconfig()
def adddata(self, zh, mac, bz):
"""通过此方法添加数据"""
if zh in self.__config:
raise Exception("zh 数据已存在") # 也可将报错改为不添加数据
for zhres in self.__config.values():
if mac in zhres:
raise Exception("mac 数据已存在") # 也可将报错改为不添加数据
self.__config =
# 如果想添加成功一次数据保存一次,此处可执行 saveconfig 方法
# self.saveconfig()
def deldata(self, zh):
"""通过此方法删除数据"""
del self.__config
def cleardata(self):
"""通过此方法清空数据"""
self.__config.clear()
def getdata(self, zh, default = None):
"""通过此方法访问数据"""
if default is None:
default = list() # 访问不存在的 zh 返回空列表
return self.__config.get(zh, default)
# 也可改为访问不存在的 zh 直接报错
def saveconfig(self):
"""通过此方法将数据储存到磁盘"""
with open(self.__path, "wt", encoding="utf8") as f:
json.dump(self.__config, f, ensure_ascii=False)
def __loadconfig(self):
"""通过此方法从磁盘载入数据"""
if not os.path.exists(self.__path):
with open(self.__path, "wt", encoding="utf8") as f:
json.dump(self.__config, f, ensure_ascii=False)
return
if self.__config:# 字典已有数据
return
if os.path.isfile(self.__path):
with open(self.__path, "rt", encoding="utf8") as f:
self.__config = json.load(f)
return
else:
raise Exception("配置文件路径是个文件夹")
def delete(self):
"""通过此方法删除配置文件"""
os.remove(self.__path)
# 配置控制器 ConfigController 的使用
config = ConfigController("./config.json")
# 添加数据
config.adddata("zh1", "a0:b6:82:79:63", "bz1")
# 添加重复 zh1:报错
# config.adddata("zh1", "00:00:00:00:00", "bz1")
# 添加重复 mac:报错
# config.adddata("zh2", "a0:b6:82:79:63", "bz1")
# 读取数据
print("zh1 的内容:",config.getdata("zh1"))
# 保存到配置文件
config.saveconfig()
wp231957 发表于 2022-9-4 21:35
谢谢,我突然发现用py自带的sqlite似乎也可以,
sqlite 不就是数据库吗,你又说不用数据库,哈哈,其实数据库最终也是要靠写到磁盘文件里才能“持久化”。
我上面只是写了一下基本的判断逻辑和代码,具体判断后 怎么写入文件(落盘),你自己看着办就好
——纯txt读写, 或借助pickle, json, csv等模块, 或 pandas.to_excel, pandas.to_csv 等方法 都可以保存数据。
ps: 这既然是设计问题,主要取决于你具体的问题需求,以及个人偏好~
页:
[1]