Pickle, som som standard er en del af Python-biblioteket, er et vigtigt modul, når du har brug for vedholdenhed mellem brugersessioner. Som et modul giver pickle mulighed for at gemme Python-objekter mellem processer.
Uanset om du programmerer til en database, spil, forum eller et andet program, der skal gemme information mellem sessioner, pickle er nyttigt til at gemme identifikatorer og indstillinger. Pickle-modulet kan gemme ting som datatyper som booleaner, strenge og byte-arrays, lister, ordbøger, funktioner og mere.
Bemærk: Begrebet pickling er også kendt som serialisering, marskalkning og udflatning. Men punktet er altid det samme - at gemme et objekt i en fil til senere hentning. Pickling opnår dette ved at skrive objektet som en lang strøm af bytes.
Pickle-eksempelkode i Python
For at skrive et objekt til en fil bruger du en kode i følgende syntaks:
import pickle
objekt = objekt ()
filehandler = åben (filnavn, 'w')
pickle.dump (objekt, filhåndterer)
Sådan ser et ægte eksempel ud:
import pickle
import matematik
object_pi = math.pi
file_pi = åben ('filnavn_pi.obj', 'w')
pickle.dump (object_pi, file_pi)
Dette uddrag skriver indholdet af object_pi til filen handler fil_pi, som igen er bundet til filen filename_pi.obj i kataloget for udførelse.
For at gendanne objektets værdi til hukommelse skal du indlæse objektet fra filen. Forudsat at pickle endnu ikke er importeret til brug, start med at importere den:
import pickle
filhåndterer = åben (filnavn, 'r')
object = pickle.load (filhåndterer)
Følgende kode gendanner pi-værdien:
import pickle
file_pi2 = åben ('filename_pi.obj', 'r')
object_pi2 = pickle.load (file_pi2)
Objektet er derefter klar til brug igen, denne gang som object_pi2. Du kan naturligvis genbruge de originale navne, hvis du foretrækker det. Dette eksempel bruger forskellige navne til klarhed.
Ting at huske på Pickle
Husk disse ting, når du bruger pickle-modulet:
- Pickle-protokollen er specifik for Python - den er ikke garanteret at være kompatibel på tværs af sprog. Du kan sandsynligvis ikke overføre informationerne for at gøre dem nyttige på Perl, PHP, Java eller andre sprog.
- Der er heller ingen garanti for kompatibilitet mellem forskellige versioner af Python. ITkompatibiliteten findes, fordi ikke alle Python-datastrukturer kan serialiseres af modulet.
- Som standard bruges den seneste version af pickle-protokollen. Det forbliver på den måde, medmindre du manuelt ændrer det.
Tip: Find også ud af det hvordan man bruger hylde til at gemme objekter i Python til en anden metode til at opretholde objektkontinuitet.