Shelve es un poderoso módulo de Python para la persistencia de objetos. Cuando archiva un objeto, debe asignar una clave por la cual se conoce el valor del objeto. De esta forma, el archivo de estantería se convierte en una base de datos de valores almacenados, a los cuales se puede acceder en cualquier momento.
Para archivar un objeto, primero importe el módulo y luego asigne el valor del objeto de la siguiente manera:
estantería de importación
database = shelve.open (filename.suffix)
objeto = Objeto ()
base de datos ['clave'] = objeto
Si desea mantener una base de datos de existencias, por ejemplo, puede adaptar el siguiente código:
estantería de importación
stockvalues_db = shelve.open ('stockvalues.db')
object_ibm = Values.ibm ()
stockvalues_db ['ibm'] = object_ibm
object_vmw = Values.vmw ()
stockvalues_db ['vmw'] = object_vmw
object_db = Values.db ()
stockvalues_db ['db'] = object_db
Ya está abierto un "stock values.db", no necesita abrirlo nuevamente. Por el contrario, puede abrir varias bases de datos a la vez, escribir en cada una a voluntad y dejar que Python las cierre cuando el programa finalice. Podría, por ejemplo, mantener una base de datos separada de nombres para cada símbolo, agregando lo siguiente al código anterior:
## asumiendo que la estantería ya está importada
stocknames_db = shelve.open ('stocknames.db')
objectname_ibm = Names.ibm ()
stocknames_db ['ibm'] = objectname_ibm
objectname_vmw = Nombres.vmw ()
stocknames_db ['vmw'] = objectname_vmw
objectname_db = Nombres.db ()
stocknames_db ['db'] = objectname_db
Tenga en cuenta que cualquier cambio en el nombre o sufijo del archivo de la base de datos constituye un archivo diferente y, por lo tanto, una base de datos diferente.
El resultado es un segundo archivo de base de datos que contiene los valores dados. A diferencia de la mayoría de los archivos escritos en formatos de estilo propio, las bases de datos archivadas se guardan en forma binaria.
Una vez que los datos se escriben en el archivo, se pueden recuperar en cualquier momento. Si desea restaurar los datos en una sesión posterior, vuelva a abrir el archivo. Si es la misma sesión, simplemente recupere el valor; los archivos de la base de datos de Shelve se abren en modo lectura-escritura La siguiente es la sintaxis básica para lograr esto:
estantería de importación
database = shelve.open (filename.suffix)
objeto = base de datos ['clave']
Entonces, una muestra del ejemplo anterior leería:
estantería de importación
stockname_file = shelve.open ('stocknames.db')
stockname_ibm = stockname_file ['ibm']
stockname_db = stockname_file ['db']
Es importante tener en cuenta que la base de datos permanece abierta hasta que la cierre (o hasta que finalice el programa). Por lo tanto, si está escribiendo un programa de cualquier tamaño, desea cerrar la base de datos después de trabajar con ella. De lo contrario, toda la base de datos (no solo el valor que desea) se almacena en la memoria y consume recursos informáticos.
Para cerrar un archivo de reserva, use la siguiente sintaxis:
database.close ()
Si todos los ejemplos de código anteriores se incorporaran en un solo programa, tendríamos dos archivos de base de datos abiertos y consumiendo memoria en este punto. Entonces, después de haber leído los nombres de las acciones en el ejemplo anterior, puede cerrar cada base de datos de la siguiente manera:
stockvalues_db.close ()
stocknames_db.close ()
stockname_file.close ()