|
|
|
|
Strumenti |
05-05-2020, 17:45 | #1 |
Senior Member
Iscritto dal: Jan 2009
Messaggi: 974
|
[Python] caricare e salvare dati su file.txt
Ciao a tutti sto provando ad imparare Python, scusate se faccio errori banali utilizzo Python 3.8 su visual studio code
sto cercando di costruire delle librerie da utilizzare per più applicazioni che fondamentalmente permettano, dato un player con un nome e un punteggio, di costruire una classifica e salvarla su un file.txt l'idea iniziale era di salvare su ogni riga una stringa così nome@punteggio e qui è nato il primo problema la stringa che leggevo era di questo tipo ['nome@punteggio\n'], ho aggirato questo problema così Codice:
def loading (): t=open("clas.txt", "r") z=1 trik={} while z<10: ty=str (t.readlines(z)) l=(len(ty)-4) pulita=ty[2:l] control=(pulita.find("@")) name=pulita[0:control] punt=pulita[(control+1):] d={z:[name,punt]} trik.update(d) z+=1 però alle ultime linee del file continuo ad avere problemi con questi \n (mancano anche se da notepad++ ci sono ) che imbrogliano il sistema di pulitura stringhe ho preso una strada completamente sbagliata ? mi conviene usare un altro metodo come salvare direttamente il dizionario sul file ( se si può fare?) o c'è un metodo più semplice per salvare e ricaricare quei dati ? mi scuso se sono stato troppo contorto
__________________
Case CM Elite 430 Mobo Asus p8h67 m DissiHyper 212 EVO Cpu i5 2500K Ram Corsair XMS3 4x2gb drr3 1333mhz Vga RX460 WINDFORCE OC 4G Hardisk Seagate Barracuda 7200.12 1t Psu Corsair cx430 Ultima modifica di zla_Stobb : 06-05-2020 alle 13:10. |
06-05-2020, 15:23 | #2 |
Senior Member
Iscritto dal: Jan 2008
Messaggi: 8406
|
Si, quando le performance non sono critiche, Python mette a disposizione un metodo universale per la serializzazione delle sue strutture dati, il pickling https://www.tutorialspoint.com/python-pickling
E direi che è preferibile. Sempre che non ci sia da gestire gazillioni di elementi. Ma in quel caso ci vorrebbe un database. Tuttavia, per ragioni di uniformità con le tecnologie più in voga al momento, un'altra strada percorribile è quella di usare il formato JSON https://appdividend.com/2019/04/15/h...-with-example/ In teoria potresti pure usare il banale CSV. Il punto è che usando formati standardizzati e/o diffusi de facto, crei un software interoperabile. Non è obbligatorio se è per hobby, ma lo è se il tuo software farà un giorno il giro del mondo. Comunque dal codice vedo alcune cose che non mi convincono. Parecchie in verità. Premetto intanto che il \n mancante può dipendere dalla configurazione di Notepad++. Tieni presente che sotto Windows si usa \r\n e non \n. Ma per gestire queste discrasie, ci sono funzioni apposite in Python. Per esempio splitlines si occupa di gestire indistintamente \r\n e \n. Quindi ritorna a capo Unix-style e Windows-style. E dovresti usarle, farne un maggiore uso. Per esempio lì vedo tutta una serie di calcoli e find, quando bastava, per ogni linea fare Codice:
ty.split("@") |
07-05-2020, 15:54 | #3 |
Senior Member
Iscritto dal: Jan 2009
Messaggi: 974
|
grazie per l'aiuto
per quanto riguarda t.readlines(z) mi legge la singola riga presente nel file con z=0 mi legge tutto il file comunque dovrei aver risolto però devo riscriverlo perchè non è il massimo
__________________
Case CM Elite 430 Mobo Asus p8h67 m DissiHyper 212 EVO Cpu i5 2500K Ram Corsair XMS3 4x2gb drr3 1333mhz Vga RX460 WINDFORCE OC 4G Hardisk Seagate Barracuda 7200.12 1t Psu Corsair cx430 |
07-05-2020, 16:09 | #4 | |
Senior Member
Iscritto dal: Jan 2008
Messaggi: 8406
|
Quote:
Questo presuppone che tu abbia righe di lunghezza costante o comunque nota a priori. E non mi pare il tuo caso. Già il nome può essere una cosa da 3-4 a 30 caratteri o più. |
|
07-05-2020, 17:06 | #5 | |
Senior Member
Iscritto dal: Jan 2009
Messaggi: 974
|
Quote:
rendendomi conto che il problema non erano i \n mettendo ora t.readlines(1) non ho più quel problema che succedeva con un k>9 perchè i nomi non erano molto lunghi e quindi caricava anche il rigo successivo considerando che nel mio file c'è un sola stringa (punteggio@nome) per rigo con un ciclo di t.readlines(1) non dovrei avere più problemi giusto o sbaglio ancora ? p.s. comunque leggendo nella documentazione readlines(hint=-1) Read and return a list of lines from the stream. hint can be specified to control the number of lines read: no more lines will be read if the total size (in bytes/characters) of all lines so far exceeds hint. Note that it’s already possible to iterate on file objects using for line in file: ... without calling file.readlines(). in questo modo dovrei risolvere definitivamente e esce anche tutto più pulito
__________________
Case CM Elite 430 Mobo Asus p8h67 m DissiHyper 212 EVO Cpu i5 2500K Ram Corsair XMS3 4x2gb drr3 1333mhz Vga RX460 WINDFORCE OC 4G Hardisk Seagate Barracuda 7200.12 1t Psu Corsair cx430 |
|
07-05-2020, 18:13 | #6 | |
Senior Member
Iscritto dal: Jan 2008
Messaggi: 8406
|
Quote:
blah blah è il modo più semplice e veloce per leggere il file una riga alla volta altrimenti si può benissimo fare righe = ty.readlines() righe è una lista e puoi scorrerla con un for for ty in righe: blah blah |
|
Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 20:38.