| Name | shihua-sunbasket JSON |
| Version |
0.1.1
JSON |
| download |
| home_page | https://github.com/redblue0216/SunBasket |
| Summary | Sunbasket is an embedded algorithmic auxiliary management tool that mainly provides five categories of information management, including algorithm, model, parameter, application, and data, model storage management, and algorithm logging. The main technologies use SQLite, ORM, and logging, and the design mode is factory mode. |
| upload_time | 2023-05-24 13:54:15 |
| maintainer | |
| docs_url | None |
| author | shihua |
| requires_python | >=3.10.9 |
| license | MIT |
| keywords |
|
| VCS |
 |
| bugtrack_url |
|
| requirements |
No requirements were recorded.
|
| Travis-CI |
No Travis.
|
| coveralls test coverage |
No coveralls.
|
# SunBasket-算法信息存储管理工具
   

## 介绍
+ SunBasket是一款嵌入式算法辅助管理工具,主要提供五类信息管理,包括算法、模型、参数、应用程序和数据、模型存储管理和算法日志。主要技术使用SQLite、ORM和logging,设计模式为工厂模式。
## 安装
SunBasket采用Python开发,得益于Python良好的社区环境,安装支持Pythonic风格的各种管理器。
```bash
$ pip install sunbasket-0.1-xxxxxxxxxxxx.whl
```
## 快速指南
+ SunBasket提供python-sdk的日志转发至SQLite的日志记录功能,算法、模型、参数、应用、数据的信息管理功能以及模型的存储功能,以下是SunBasket主程脚本示例:
```python
import logging
from sunbasket.handler import SQLiteHandler
from sunbasket.data import AlgorithmInfoManager,ModelInfoManager,ParameterInfoManager,ApplicationInfoManager,DataInfoManager,ModelStoreManager,serialize_data,deserialize_data
####### 手动日志测试
### 创建日志操作对象
logger = logging.getLogger()
### 设置日志操作对象的日志等级
logger.setLevel(logging.INFO)
### 创建一个SQLite处理器
# SQLiteHandler = SQLiteHandler(log_database='sqlite:///E:\\workspace\\SunBasket\\Demo\\test.db')
SQLiteHandler = SQLiteHandler()
### 设置SQLite处理器的日志等级
SQLiteHandler.setLevel(logging.INFO)
### 向日志操作对象添加SQLite处理器
logger.addHandler(SQLiteHandler)
logger.info('start test log handler')
logger.warning('this is a warning log')
####### 信息管理测试
### 连接数据库
connect_info = 'sqlite:///E:\\workspace\\SunBasket\\Demo\\test.db'
### 算法信息管理
algorithm_info_data_dict = {
'name': 'test',
'version': 'v001',
'summary': 'test summary',
'config': 'test config',
'remark': 'test remark',
'homepage': 'test homepage',
'author': 'shihua',
'authoremail': 'xxxxx@xxx.com',
'license': 'MIT',
'requires': 'numpy,pandas',
'requiredby': 'xxxx'
}
algorithm_info = AlgorithmInfoManager(connect_info=connect_info,data_dict=algorithm_info_data_dict)
algorithm_info.add_data()
### 模型信息管理
model_info_data_dict = {
'name': 'test',
'version': 'v001',
'summary': 'test summary',
'config': 'test config',
'remark': 'test remark',
'requires': 'numpy,pandas',
'data': 'test data',
'algorithm': 'test algorithm'
}
model_info = ModelInfoManager(connect_info=connect_info,data_dict=model_info_data_dict)
model_info.add_data()
### 参数信息管理
parameter_info_data_dict = {
'name': 'test',
'version': 'v001',
'summary': 'test summary',
'config': 'test config',
'remark': 'test remark',
'datatype': 'test datatype',
'requiredby': 'xxxx'
}
parameter_info = ParameterInfoManager(connect_info=connect_info,data_dict=parameter_info_data_dict)
parameter_info.add_data()
### 应用信息管理
application_info_data_dict = {
'name': 'test',
'version': 'v001',
'summary': 'test summary',
'config': 'test config',
'remark': 'test remark',
'requires': 'test requires',
'project': 'xxxx'
}
application_info = ApplicationInfoManager(connect_info=connect_info,data_dict=application_info_data_dict)
application_info.add_data()
### 数据信息管理
data_info_data_dict = {
'name': 'test',
'version': 'v001',
'summary': 'test summary',
'config': 'test config',
'remark': 'test remark',
'requireby': 'test requiredby',
'datatype': 'test datatype',
'project': 'xxxx'
}
data_info = DataInfoManager(connect_info=connect_info,data_dict=data_info_data_dict)
data_info.add_data()
####### 存储管理测试
### 模型存储管理
class TestModel(object):
def __init__(self,name):
self.name = name
self.arg = 150
def add(self,a,b):
return a+b
test_model = TestModel(name='testmodel')
### 序列化数据对象
serialized_data = serialize_data(data=test_model)
model_store_data_dict = {
'name': 'test',
'version': 'v001',
'summary': 'test summary',
'config': 'test config',
'remark': 'test remark',
'data': serialized_data
}
model_store = ModelStoreManager(connect_info=connect_info,data_dict=model_store_data_dict)
model_store.add_data()
### 读取目标模型
tmp_model = model_store.get_model_data(connect_info=connect_info,name='test',version='v001')
### 反序列化数据对象
tmp_model_data = deserialize_data(serialized_data=tmp_model.data)
print(tmp_model_data.name,tmp_model_data.arg,tmp_model_data.add(1,2))
```
## 设计
+ 基于python基础包logging开发日志转发处理器
+ 使用SQLite作为日志存储后端
+ 支持日志过滤和日志信息选择
+ 管理算法、模型、参数、应用和数据五大类信息
+ 模型的存储管理
### 技术列表
+ 数据库-SQLite
+ ORM
+ logging
+ 配置文件-yaml
+ 继承重写
+ 静态方法
+ 对象化
### 设计UML图
以下是设计的UML图:

Raw data
{
"_id": null,
"home_page": "https://github.com/redblue0216/SunBasket",
"name": "shihua-sunbasket",
"maintainer": "",
"docs_url": null,
"requires_python": ">=3.10.9",
"maintainer_email": "",
"keywords": "",
"author": "shihua",
"author_email": "15021408795@163.com",
"download_url": "https://files.pythonhosted.org/packages/e9/4b/81aea59518aaf548c4c59d0cd24a50f9587457f443a6131338b65f18daba/shihua-sunbasket-0.1.1.tar.gz",
"platform": null,
"description": "# SunBasket-\u7b97\u6cd5\u4fe1\u606f\u5b58\u50a8\u7ba1\u7406\u5de5\u5177\r\n\r\n   \r\n\r\n\r\n\r\n\r\n## \u4ecb\u7ecd\r\n+ SunBasket\u662f\u4e00\u6b3e\u5d4c\u5165\u5f0f\u7b97\u6cd5\u8f85\u52a9\u7ba1\u7406\u5de5\u5177\uff0c\u4e3b\u8981\u63d0\u4f9b\u4e94\u7c7b\u4fe1\u606f\u7ba1\u7406\uff0c\u5305\u62ec\u7b97\u6cd5\u3001\u6a21\u578b\u3001\u53c2\u6570\u3001\u5e94\u7528\u7a0b\u5e8f\u548c\u6570\u636e\u3001\u6a21\u578b\u5b58\u50a8\u7ba1\u7406\u548c\u7b97\u6cd5\u65e5\u5fd7\u3002\u4e3b\u8981\u6280\u672f\u4f7f\u7528SQLite\u3001ORM\u548clogging\uff0c\u8bbe\u8ba1\u6a21\u5f0f\u4e3a\u5de5\u5382\u6a21\u5f0f\u3002\r\n\r\n\r\n## \u5b89\u88c5\r\nSunBasket\u91c7\u7528Python\u5f00\u53d1\uff0c\u5f97\u76ca\u4e8ePython\u826f\u597d\u7684\u793e\u533a\u73af\u5883\uff0c\u5b89\u88c5\u652f\u6301Pythonic\u98ce\u683c\u7684\u5404\u79cd\u7ba1\u7406\u5668\u3002\r\n\r\n```bash\r\n\t$ pip install sunbasket-0.1-xxxxxxxxxxxx.whl\r\n```\r\n\r\n\r\n## \u5feb\u901f\u6307\u5357\r\n+ SunBasket\u63d0\u4f9bpython-sdk\u7684\u65e5\u5fd7\u8f6c\u53d1\u81f3SQLite\u7684\u65e5\u5fd7\u8bb0\u5f55\u529f\u80fd\uff0c\u7b97\u6cd5\u3001\u6a21\u578b\u3001\u53c2\u6570\u3001\u5e94\u7528\u3001\u6570\u636e\u7684\u4fe1\u606f\u7ba1\u7406\u529f\u80fd\u4ee5\u53ca\u6a21\u578b\u7684\u5b58\u50a8\u529f\u80fd,\u4ee5\u4e0b\u662fSunBasket\u4e3b\u7a0b\u811a\u672c\u793a\u4f8b\uff1a\r\n\r\n```python\r\nimport logging\r\nfrom sunbasket.handler import SQLiteHandler\r\nfrom sunbasket.data import AlgorithmInfoManager,ModelInfoManager,ParameterInfoManager,ApplicationInfoManager,DataInfoManager,ModelStoreManager,serialize_data,deserialize_data\r\n\r\n\r\n\r\n####### \u624b\u52a8\u65e5\u5fd7\u6d4b\u8bd5\r\n### \u521b\u5efa\u65e5\u5fd7\u64cd\u4f5c\u5bf9\u8c61\r\nlogger = logging.getLogger()\r\n### \u8bbe\u7f6e\u65e5\u5fd7\u64cd\u4f5c\u5bf9\u8c61\u7684\u65e5\u5fd7\u7b49\u7ea7\r\nlogger.setLevel(logging.INFO)\r\n### \u521b\u5efa\u4e00\u4e2aSQLite\u5904\u7406\u5668\r\n# SQLiteHandler = SQLiteHandler(log_database='sqlite:///E:\\\\workspace\\\\SunBasket\\\\Demo\\\\test.db')\r\nSQLiteHandler = SQLiteHandler()\r\n### \u8bbe\u7f6eSQLite\u5904\u7406\u5668\u7684\u65e5\u5fd7\u7b49\u7ea7\r\nSQLiteHandler.setLevel(logging.INFO)\r\n### \u5411\u65e5\u5fd7\u64cd\u4f5c\u5bf9\u8c61\u6dfb\u52a0SQLite\u5904\u7406\u5668\r\nlogger.addHandler(SQLiteHandler)\r\nlogger.info('start test log handler')\r\nlogger.warning('this is a warning log')\r\n\r\n\r\n\r\n####### \u4fe1\u606f\u7ba1\u7406\u6d4b\u8bd5\r\n### \u8fde\u63a5\u6570\u636e\u5e93 \r\nconnect_info = 'sqlite:///E:\\\\workspace\\\\SunBasket\\\\Demo\\\\test.db'\r\n### \u7b97\u6cd5\u4fe1\u606f\u7ba1\u7406\r\nalgorithm_info_data_dict = {\r\n\t'name': 'test',\r\n\t'version': 'v001',\r\n\t'summary': 'test summary',\r\n\t'config': 'test config',\r\n\t'remark': 'test remark',\r\n\t'homepage': 'test homepage',\r\n\t'author': 'shihua',\r\n\t'authoremail': 'xxxxx@xxx.com',\r\n\t'license': 'MIT',\r\n\t'requires': 'numpy,pandas',\r\n\t'requiredby': 'xxxx'\r\n}\r\nalgorithm_info = AlgorithmInfoManager(connect_info=connect_info,data_dict=algorithm_info_data_dict)\r\nalgorithm_info.add_data()\r\n\r\n\r\n### \u6a21\u578b\u4fe1\u606f\u7ba1\u7406\r\nmodel_info_data_dict = {\r\n\t'name': 'test',\r\n\t'version': 'v001',\r\n\t'summary': 'test summary',\r\n\t'config': 'test config',\r\n\t'remark': 'test remark',\r\n\t'requires': 'numpy,pandas',\r\n\t'data': 'test data',\r\n\t'algorithm': 'test algorithm'\r\n}\r\nmodel_info = ModelInfoManager(connect_info=connect_info,data_dict=model_info_data_dict)\r\nmodel_info.add_data()\r\n\r\n\r\n### \u53c2\u6570\u4fe1\u606f\u7ba1\u7406\r\nparameter_info_data_dict = {\r\n\t'name': 'test',\r\n\t'version': 'v001',\r\n\t'summary': 'test summary',\r\n\t'config': 'test config',\r\n\t'remark': 'test remark',\r\n\t'datatype': 'test datatype',\r\n\t'requiredby': 'xxxx'\r\n}\r\nparameter_info = ParameterInfoManager(connect_info=connect_info,data_dict=parameter_info_data_dict)\r\nparameter_info.add_data()\r\n\r\n\r\n### \u5e94\u7528\u4fe1\u606f\u7ba1\u7406\r\napplication_info_data_dict = {\r\n\t'name': 'test',\r\n\t'version': 'v001',\r\n\t'summary': 'test summary',\r\n\t'config': 'test config',\r\n\t'remark': 'test remark',\r\n\t'requires': 'test requires',\r\n\t'project': 'xxxx'\r\n}\r\napplication_info = ApplicationInfoManager(connect_info=connect_info,data_dict=application_info_data_dict)\r\napplication_info.add_data()\r\n\r\n\r\n### \u6570\u636e\u4fe1\u606f\u7ba1\u7406\r\ndata_info_data_dict = {\r\n\t'name': 'test',\r\n\t'version': 'v001',\r\n\t'summary': 'test summary',\r\n\t'config': 'test config',\r\n\t'remark': 'test remark',\r\n\t'requireby': 'test requiredby',\r\n\t'datatype': 'test datatype',\r\n\t'project': 'xxxx'\r\n}\r\ndata_info = DataInfoManager(connect_info=connect_info,data_dict=data_info_data_dict)\r\ndata_info.add_data()\r\n\r\n\r\n\r\n####### \u5b58\u50a8\u7ba1\u7406\u6d4b\u8bd5\r\n### \u6a21\u578b\u5b58\u50a8\u7ba1\u7406\r\nclass TestModel(object):\r\n\r\n\tdef __init__(self,name):\r\n\t\tself.name = name\r\n\t\tself.arg = 150\r\n\r\n\tdef add(self,a,b):\r\n\t\treturn a+b\r\ntest_model = TestModel(name='testmodel')\r\n### \u5e8f\u5217\u5316\u6570\u636e\u5bf9\u8c61\r\nserialized_data = serialize_data(data=test_model) \r\nmodel_store_data_dict = {\r\n\t'name': 'test',\r\n\t'version': 'v001',\r\n\t'summary': 'test summary',\r\n\t'config': 'test config',\r\n\t'remark': 'test remark',\r\n\t'data': serialized_data\r\n}\r\nmodel_store = ModelStoreManager(connect_info=connect_info,data_dict=model_store_data_dict)\r\nmodel_store.add_data()\r\n\r\n\r\n### \u8bfb\u53d6\u76ee\u6807\u6a21\u578b\r\ntmp_model = model_store.get_model_data(connect_info=connect_info,name='test',version='v001')\r\n### \u53cd\u5e8f\u5217\u5316\u6570\u636e\u5bf9\u8c61\r\ntmp_model_data = deserialize_data(serialized_data=tmp_model.data)\r\nprint(tmp_model_data.name,tmp_model_data.arg,tmp_model_data.add(1,2))\r\n```\r\n\r\n\r\n## \u8bbe\u8ba1\r\n+ \u57fa\u4e8epython\u57fa\u7840\u5305logging\u5f00\u53d1\u65e5\u5fd7\u8f6c\u53d1\u5904\u7406\u5668\r\n+ \u4f7f\u7528SQLite\u4f5c\u4e3a\u65e5\u5fd7\u5b58\u50a8\u540e\u7aef\r\n+ \u652f\u6301\u65e5\u5fd7\u8fc7\u6ee4\u548c\u65e5\u5fd7\u4fe1\u606f\u9009\u62e9\r\n+ \u7ba1\u7406\u7b97\u6cd5\u3001\u6a21\u578b\u3001\u53c2\u6570\u3001\u5e94\u7528\u548c\u6570\u636e\u4e94\u5927\u7c7b\u4fe1\u606f\r\n+ \u6a21\u578b\u7684\u5b58\u50a8\u7ba1\u7406\r\n\r\n\r\n### \u6280\u672f\u5217\u8868\r\n+ \u6570\u636e\u5e93-SQLite\r\n+ ORM\r\n+ logging\r\n+ \u914d\u7f6e\u6587\u4ef6-yaml\r\n+ \u7ee7\u627f\u91cd\u5199\r\n+ \u9759\u6001\u65b9\u6cd5\r\n+ \u5bf9\u8c61\u5316\r\n\r\n\r\n### \u8bbe\u8ba1UML\u56fe\r\n\u4ee5\u4e0b\u662f\u8bbe\u8ba1\u7684UML\u56fe\uff1a\r\n\r\n\r\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "Sunbasket is an embedded algorithmic auxiliary management tool that mainly provides five categories of information management, including algorithm, model, parameter, application, and data, model storage management, and algorithm logging. The main technologies use SQLite, ORM, and logging, and the design mode is factory mode.",
"version": "0.1.1",
"project_urls": {
"Homepage": "https://github.com/redblue0216/SunBasket"
},
"split_keywords": [],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "9cb0ce003d28c91b33eb6f0cc8dd7b9dbb735dae577134aed5ef4e9ca5d86833",
"md5": "6b249c8315ccfb2e621769ac8272c49c",
"sha256": "734de43884c2d9931c54b113d957af4631d03134a5675b4b9ac401b55caef14f"
},
"downloads": -1,
"filename": "shihua_sunbasket-0.1.1-py3-none-any.whl",
"has_sig": false,
"md5_digest": "6b249c8315ccfb2e621769ac8272c49c",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.10.9",
"size": 17491,
"upload_time": "2023-05-24T13:54:13",
"upload_time_iso_8601": "2023-05-24T13:54:13.285307Z",
"url": "https://files.pythonhosted.org/packages/9c/b0/ce003d28c91b33eb6f0cc8dd7b9dbb735dae577134aed5ef4e9ca5d86833/shihua_sunbasket-0.1.1-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "e94b81aea59518aaf548c4c59d0cd24a50f9587457f443a6131338b65f18daba",
"md5": "a7d8d12e21f5418ef1c0744f6c38c1b8",
"sha256": "d9ac026332344d50d007deaffc2c735bf061b353902ad650ef3397d861f350a2"
},
"downloads": -1,
"filename": "shihua-sunbasket-0.1.1.tar.gz",
"has_sig": false,
"md5_digest": "a7d8d12e21f5418ef1c0744f6c38c1b8",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.10.9",
"size": 12155,
"upload_time": "2023-05-24T13:54:15",
"upload_time_iso_8601": "2023-05-24T13:54:15.831986Z",
"url": "https://files.pythonhosted.org/packages/e9/4b/81aea59518aaf548c4c59d0cd24a50f9587457f443a6131338b65f18daba/shihua-sunbasket-0.1.1.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2023-05-24 13:54:15",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "redblue0216",
"github_project": "SunBasket",
"travis_ci": false,
"coveralls": false,
"github_actions": false,
"lcname": "shihua-sunbasket"
}