Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Appian: non solo low code. La missione è l’ottimizzazione dei processi con l'IA
Appian: non solo low code. La missione è l’ottimizzazione dei processi con l'IA
Abbiamo partecipato ad Appian World 2024, evento dedicato a partner e clienti che si è svolto recentemente nei pressi di Washington DC, vicino alla sede storica dell’azienda. Nel festeggiare il 25mo anniversario, Appian ha annunciato diverse novità in ambito intelligenza artificiale
Lenovo ThinkVision 3D 27, la steroscopia senza occhialini
Lenovo ThinkVision 3D 27, la steroscopia senza occhialini
Primo contatto con il monitor Lenovo ThinkVision 3D 27 che grazie a particolari accorgimenti tecnici riesce a ricreare l'illusione della spazialità tridimensionale senza che sia necessario utilizzare occhialini
La Formula E può correre su un tracciato vero? Reportage da Misano con Jaguar TCS Racing
La Formula E può correre su un tracciato vero? Reportage da Misano con Jaguar TCS Racing
Abbiamo visto ancora una volta la Formula E da vicino, ospiti di Jaguar TCS Racing. In questa occasione però curve e rettilinei erano quelli di un circuito permanente, molto diverso dagli stretti passaggi delle strade di Roma
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 05-05-2020, 16:45   #1
zla_Stobb
Senior Member
 
L'Avatar di zla_Stobb
 
Iscritto dal: Jan 2009
Messaggi: 975
[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
in questo modo ho un dizionario con {posizione :[nome, punteggio]}

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 12:10.
zla_Stobb è offline   Rispondi citando il messaggio o parte di esso
Old 06-05-2020, 14:23   #2
pabloski
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("@")
E la cosa che proprio non capisco è quel t.readlines(z)?? il valore passato a quella funzione è il sizehint, cioè quanti byte deve leggere al massimo. Come hai fatto tu, leggi al primo passo 1 byte, al secondo 2 bytes, al terzo 3 bytes e così via fino a 9. E onestamente, mi sa che così non arriva a completare nemmeno la lettura della prima riga.
pabloski è offline   Rispondi citando il messaggio o parte di esso
Old 07-05-2020, 14:54   #3
zla_Stobb
Senior Member
 
L'Avatar di zla_Stobb
 
Iscritto dal: Jan 2009
Messaggi: 975
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
zla_Stobb è offline   Rispondi citando il messaggio o parte di esso
Old 07-05-2020, 15:09   #4
pabloski
Senior Member
 
Iscritto dal: Jan 2008
Messaggi: 8406
Quote:
Originariamente inviato da zla_Stobb Guarda i messaggi
per quanto riguarda t.readlines(z) mi legge la singola riga presente nel file
Stacci attento. Quella cosa lì dice: "comincia a leggere la prima riga e se il numero di bytes letti è maggiore a z, allora fermati".

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ù.
pabloski è offline   Rispondi citando il messaggio o parte di esso
Old 07-05-2020, 16:06   #5
zla_Stobb
Senior Member
 
L'Avatar di zla_Stobb
 
Iscritto dal: Jan 2009
Messaggi: 975
Quote:
Originariamente inviato da pabloski Guarda i messaggi
Stacci attento. Quella cosa lì dice: "comincia a leggere la prima riga e se il numero di bytes letti è maggiore a z, allora fermati".

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ù.
si infatti dopo quello che avevi detto ho fatto dei test

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
zla_Stobb è offline   Rispondi citando il messaggio o parte di esso
Old 07-05-2020, 17:13   #6
pabloski
Senior Member
 
Iscritto dal: Jan 2008
Messaggi: 8406
Quote:
Originariamente inviato da zla_Stobb Guarda i messaggi
con un ciclo di t.readlines(1) non dovrei avere più problemi giusto o sbaglio ancora ?
for ty in t:
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
pabloski è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Appian: non solo low code. La missione è l’ottimizzazione dei processi con l'IA Appian: non solo low code. La missione è ...
Lenovo ThinkVision 3D 27, la steroscopia senza occhialini Lenovo ThinkVision 3D 27, la steroscopia senza o...
La Formula E può correre su un tracciato vero? Reportage da Misano con Jaguar TCS Racing La Formula E può correre su un tracciato ...
Lenovo LEGION e LOQ: due notebook diversi, stessa anima gaming Lenovo LEGION e LOQ: due notebook diversi, stess...
Nothing Ear e Ear (a): gli auricolari per tutti i gusti! La ''doppia'' recensione Nothing Ear e Ear (a): gli auricolari per tutti ...
D-Wave annuncia la disponibilità ...
AWS aggiorna Amazon Bedrock con nuove fu...
Sonos: in arrivo un restyling completo p...
La Russia ha condannato il direttore del...
Dead Island 2 arriva finalmente su Steam...
Era già il tablet più conv...
Razer Viper V3 Pro: il mouse da gaming w...
Noctua NH-L12Sx77: il dissipatore per bu...
AVM FRITZ!Repeater 1200 AX: il più vendu...
Apple presenterà i nuovi iPad il ...
SAP introduce l'IA nelle sue soluzioni p...
OnePlus lancia in Europa il nuovo Watch ...
La US Air Force ha condotto un test con ...
Gigabyte aggiorna la garanzia dell’inter...
Seagate annuncia gli aumenti: l’impennat...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 17:50.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Served by www1v