JsonDB는 Python으로 구현된 JSON 형식을 기반으로 하는 경량 데이터베이스 오픈 소스 프로젝트입니다. 프로젝트 주소는 https://github.com/hujiang001/jsonDB/입니다.
저자는 완전한 참조 문서를 제공하며 중국어로 되어 있어 시작하기가 매우 쉽습니다. 중국어 문서의 주소는 https://github.com/hujiang001/jsonDB/입니다. 위키/참조 문서 . 현재 이 문서는 프로젝트 프로젝트인 reference.md에도 포함되어 있습니다.
이 프로젝트는 예제도 제공합니다. 아래에 이 예제를 붙여넣으면 사용이 매우 간단하다는 것을 알 수 있습니다. 🎜 >
#!usr/bin/env python# -*- coding: utf-8 -*-from database import JSONDBif __name__=="__main__": shopDb = JSONDB('shop_db',hashSize=1) #create shop db userDb = JSONDB('sellerDb',hashSize=1) #create user db #specify key shopDb.ensureKey('shop',['id']) shopDb.ensureKey('goods',['id']) userDb.ensureKey('seller',['id','name']) userDb.ensureKey('customer',['id','name']) #for debugging, you can start perfDot and open debug switch shopDb.perfDotStart() userDb.perfDotStart() shopDb.debugSwitch(1) userDb.debugSwitch(1) #insert data #here we insert some data for i in range(0,100): #insert data one by one shopDb.insert('shop',[{'id':i, 'name':'my shop', 'description':'this is a telephone shop'}]) #inset a data list goodsList = [{'id':10001, 'class':'telephone', 'brand':'apple', 'color':'white'}, {'id':10002, 'class':'telephone', 'brand':'huawei', 'color':'black'}, {'id':10003, 'class':'telephone', 'brand':'zte', 'color':'white'}, {'id':10004, 'class':'telephone', 'brand':'xiaomi', 'color':'black'}, {'id':10005, 'class':'telephone', 'brand':'moto', 'color':'white'}, {'id':10006, 'class':'telephone', 'brand':'oppo', 'color':'black'},] shopDb.insert('goods',goodsList) sellersList = [{'id':0x34200,'name':'li','sex':'female','birth':'1985-09-03','tel':'0816-19876545432'}, {'id':0x34201,'name':'wang','sex':'male','birth':'1988-11-03','tel':'0816-2345453453'}, {'id':0x34202,'name':'hong','sex':'female','birth':'1995-10-19','tel':'0816-144567589'}] userDb.insert('seller',sellersList) customersList = [{'id':0x7800,'name':'zhu','sex':'female','profile':['dress','mother','sport']}, {'id':0x7801,'name':'rong','sex':'male','profile':['baby','read','tech']}, {'id':0x7802,'name':'guo','sex':'female','profile':['phone','dress','food']}] userDb.insert('customer',customersList) #export to default file shopDb.exportToFile() userDb.exportToFile(fileName='user') #find # find with key findList = shopDb.find('goods',filter={'id':{'$lt':10004}}) JSONDB.rprint(findList) findList = shopDb.find('goods',filter={'id':10004}) JSONDB.rprint(findList) findList = userDb.find('customer',filter={'name':'guo'}) JSONDB.rprint(findList) #delete shopDb.delete('goods',{'id':10005}) #update shopDb.update('goods',set={'class':'phone'}) #merge shopDb.merge(userDb) shopDb.exportToFile('mergeDb') #show pref time shopDb.perfDotEnd() userDb.perfDotEnd() #import importDb = JSONDB('importDb') importDb.debugSwitch(1) importDb.importFromFile(fileName='mergeDb') #importDb.printAll() importDb.exportToFile() print importDb