새로운

Python에서 Shelve를 사용하여 객체 저장

Python에서 Shelve를 사용하여 객체 저장

Shelve는 객체 지속성을위한 강력한 Python 모듈입니다. 객체를 선반에 놓을 때 객체 값을 알 수있는 키를 할당해야합니다. 이런 식으로 shelve 파일은 저장된 값의 데이터베이스가되며 언제든지 액세스 할 수 있습니다.

파이썬 쉘프 샘플 코드

객체를 선반에 놓으려면 먼저 모듈을 가져온 후 다음과 같이 객체 값을 지정하십시오.

수입 선반
데이터베이스 = shelve.open (filename.suffix)
객체 = 객체 ()
database'key '= 객체

예를 들어 주식 데이터베이스를 유지하려는 경우 다음 코드를 적용 할 수 있습니다.

수입 선반
stockvalues_db = shelve.open ( 'stockvalues.db')
object_ibm = Values.ibm ()
stockvalues_db'ibm '= object_ibm
object_vmw = 값 .vmw ()
stockvalues_db'vmw '= object_vmw
object_db = Values.db ()
stockvalues_db'db '= object_db

"stock values.db"가 이미 열려 있으므로 다시 열 필요가 없습니다. 오히려 한 번에 여러 데이터베이스를 열고 원하는대로 각 데이터베이스에 쓰고 프로그램이 종료되면 Python을 닫아 데이터베이스를 닫을 수 있습니다. 예를 들어 각 코드에 대해 별도의 이름 데이터베이스를 유지하여 앞의 코드에 다음을 추가 할 수 있습니다.

## 선반이 이미 임포트되었다고 가정
stocknames_db = shelve.open ( 'stocknames.db')
objectname_ibm = Names.ibm ()
stocknames_db'ibm '= objectname_ibm
objectname_vmw = Names.vmw ()
stocknames_db'vmw '= objectname_vmw
objectname_db = Names.db ()
stocknames_db'db '= objectname_db

데이터베이스 파일의 이름 또는 접미사를 변경하면 다른 파일과 다른 데이터베이스를 구성합니다.

결과는 주어진 값을 포함하는 두 번째 데이터베이스 파일입니다. 자체 스타일 형식으로 작성된 대부분의 파일과 달리 선반 데이터베이스는 이진 형식으로 저장됩니다.

데이터가 파일에 기록 된 후 언제든지 불러올 수 있습니다. 이후 세션에서 데이터를 복원하려면 파일을 다시여십시오. 동일한 세션 인 경우 간단히 값을 불러 오십시오. 쉘프 데이터베이스 파일은 읽기-쓰기 모드로 열립니다. 이를 달성하기위한 기본 구문은 다음과 같습니다.

수입 선반
데이터베이스 = shelve.open (filename.suffix)
객체 = 데이터베이스 키

따라서 이전 예제의 샘플은 다음과 같습니다.

수입 선반
stockname_file = shelve.open ( 'stocknames.db')
stockname_ibm = stockname_file'ibm '
stockname_db = stockname_file'db '

선반에 대한 고려 사항

데이터베이스는 닫을 때까지 (또는 프로그램이 종료 될 때까지) 열린 상태로 유지되어야합니다. 따라서 모든 크기의 프로그램을 작성하는 경우 작업 후 데이터베이스를 닫으려고합니다. 그렇지 않으면 전체 데이터베이스 (원하는 값뿐만 아니라)가 메모리에 저장되어 컴퓨팅 리소스를 소비합니다.

쉘프 파일을 닫으려면 다음 구문을 사용하십시오.

database.close ()

위의 모든 코드 예제가 하나의 프로그램에 통합 된 경우이 시점에서 두 개의 데이터베이스 파일을 열고 메모리를 사용하게됩니다. 따라서 이전 예제에서 주식 이름을 읽은 후 다음과 같이 각 데이터베이스를 차례로 닫을 수 있습니다.

stockvalues_db.close ()
stocknames_db.close ()
stockname_file.close ()