Torna indietro   Hardware Upgrade Forum > Software > Programmazione

HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare
HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare
A New York HP ha messo al centro della scena HP IQ, la piattaforma di IA locale da 20 miliardi di parametri. L’abbiamo vista in funzione: è uno strumento che funziona, pensato per un target specifico, con vantaggi reali e limiti altrettanto evidenti
PNY RTX 5080 Slim OC, sembra una Founders Edition ma non lo è
PNY RTX 5080 Slim OC, sembra una Founders Edition ma non lo è
La PNY GeForce RTX 5080 Slim OC si distingue nel panorama delle GPU di fascia alta per il design compatto a due slot, ispirato alla NVIDIA GeForce RTX 5080 Founders Edition. In questo test analizziamo comportamento termico e prestazioni in gioco, valutando se il formato ridotto comprometta o meno l'esperienza complessiva rispetto alle soluzioni più ingombranti presenti sul mercato.
Wi-Fi 7 con il design di una vetta innevata: ecco il nuovo sistema mesh di Huawei
Wi-Fi 7 con il design di una vetta innevata: ecco il nuovo sistema mesh di Huawei
HUAWEI WiFi Mesh X3 Pro Suite è probabilmente il router mesh più fotogenico che si possa acquistare oggi in Italia, ma dietro il guscio in acrilico trasparente e le luci LED dinamiche c'è una macchina tecnica costruita attorno allo standard Wi-Fi 7, con velocità teoriche Dual-Band fino a 3,6 Gbps e una copertura fino a 120 m² una volta abbinato il router principale all'extender incluso nel kit
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 27-12-2005, 17:07   #1
motogpdesmo16
Senior Member
 
Iscritto dal: Feb 2004
Città: Molfetta (BA) Squadra:BARI
Messaggi: 1085
[java]operazioni su file di testo

amici, sono niubbissimo di java.
Vorrei sapere se è possibile effettuare delle operazioni sui file. MI trovo a dover creare un programma che, dato in input un testo, in una non meglio specificata modalità, effettua su di esso alcune operazioni.
L'idea che ho è quella di valorizzare un file e, se possibile appunto, effettuare tali operazioni su di esso trattandolo come un file di testo appunto.
Le operazioni da fare sono: calcolare il numero di parole, di caratteri ecc ecc
Inoltre il testo deve essere scritto a linee.
E' fattibile una cosa del genere oppure mi conviene pensare, per semplicità, ad una struttura dati diversa??
grazie
__________________
Ho felicemente trattato con: Raziel1984,]Rik`[,fab77,pralina,vin81,drago,Qrama,Hangar18,gallo85,kikbond
motogpdesmo16 è offline   Rispondi citando il messaggio o parte di esso
Old 27-12-2005, 17:29   #2
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da motogpdesmo16
amici, sono niubbissimo di java.
Vorrei sapere se è possibile effettuare delle operazioni sui file. MI trovo a dover creare un programma che, dato in input un testo, in una non meglio specificata modalità, effettua su di esso alcune operazioni.
L'idea che ho è quella di valorizzare un file e, se possibile appunto, effettuare tali operazioni su di esso trattandolo come un file di testo appunto.
Le operazioni da fare sono: calcolare il numero di parole, di caratteri ecc ecc
Inoltre il testo deve essere scritto a linee.
E' fattibile una cosa del genere oppure mi conviene pensare, per semplicità, ad una struttura dati diversa??
grazie
Ciao, certo che puoi fare delle operazioni sui file in Java. Non ti garantisco che sarà più semplice rispetto a farle in Perl ma si può fare.
Ecco un esempio di lettura, riga per riga, di un file di testo (ho omesso per brevità import, eccezioni, ecc...):

Codice:
FileReader fr = new FileReader ("testo.txt");
BufferedReader br = new BufferedReader (fr);

String line;

while ((line = br.readLine ()) != null)
{
    /* ... fai quello che vuoi ... */
}
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 27-12-2005, 17:38   #3
motogpdesmo16
Senior Member
 
Iscritto dal: Feb 2004
Città: Molfetta (BA) Squadra:BARI
Messaggi: 1085
grazie per la veloce risposta.
Praticamente posso fare anche i calcoli relativi a lunghezza in caratteri del file di testo, numero di parole ecc ecc.?
Il file di testo poi, in fase di analisi e quindi quando sarà sottoposto agli algoritimi che ho già realizzato, sarà considerato come un testo multilinea oppure un come se fosse scritto di continuo??
__________________
Ho felicemente trattato con: Raziel1984,]Rik`[,fab77,pralina,vin81,drago,Qrama,Hangar18,gallo85,kikbond
motogpdesmo16 è offline   Rispondi citando il messaggio o parte di esso
Old 27-12-2005, 17:55   #4
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da motogpdesmo16
grazie per la veloce risposta.
Praticamente posso fare anche i calcoli relativi a lunghezza in caratteri del file di testo, numero di parole ecc ecc.?
Il file di testo poi, in fase di analisi e quindi quando sarà sottoposto agli algoritimi che ho già realizzato, sarà considerato come un testo multilinea oppure un come se fosse scritto di continuo??
L'esempio che ho fatto consente di ottenere il file riga per riga. Cosa ci fai con la riga dipende da cosa devi realizzare. Se per esempio devi contare le parole, puoi splittare la riga in tante stringhe con una regular expression:
Codice:
String[] stringhe = line.split ("\\s+");
Nota che \s+ è una espressione regolare che corrisponde a una sequenza di "whitespace character". E poi conti quante stringhe hai ottenuto (stringhe.length) e le totalizzi.
Comunque, oltre al modo riga-per-riga, puoi anche leggere il file carattere per carattere.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 27-12-2005, 18:07   #5
motogpdesmo16
Senior Member
 
Iscritto dal: Feb 2004
Città: Molfetta (BA) Squadra:BARI
Messaggi: 1085
Ho creato un piccolo programmino che deve essere alla base di quello che sarà il progetto:
Codice:
import java.lang.Object;

public class textanalyzer
{
		
	public static void main (String[] args)	
	{
	
		FileReader fr = new FileReader ("c:\testo.txt");
		BufferedReader br = new BufferedReader (fr);

		String line;
		while ((line = br.readLine ()) != null)
		{
			system.out.println ("FIle" +fr+ "letto correttamente");
		}
	}
}
E' giusta l'importazione che faccio??
Perchè ottengo errori "Cannot find symbol Filereader" e stesso errore con "BufferReader" finale.
__________________
Ho felicemente trattato con: Raziel1984,]Rik`[,fab77,pralina,vin81,drago,Qrama,Hangar18,gallo85,kikbond
motogpdesmo16 è offline   Rispondi citando il messaggio o parte di esso
Old 27-12-2005, 18:12   #6
motogpdesmo16
Senior Member
 
Iscritto dal: Feb 2004
Città: Molfetta (BA) Squadra:BARI
Messaggi: 1085
Quote:
Originariamente inviato da andbin
L'esempio che ho fatto consente di ottenere il file riga per riga. Cosa ci fai con la riga dipende da cosa devi realizzare. Se per esempio devi contare le parole, puoi splittare la riga in tante stringhe con una regular expression:
Codice:
String[] stringhe = line.split ("\\s+");
Nota che \s+ è una espressione regolare che corrisponde a una sequenza di "whitespace character". E poi conti quante stringhe hai ottenuto (stringhe.length) e le totalizzi.
Comunque, oltre al modo riga-per-riga, puoi anche leggere il file carattere per carattere.
come detto, sul file devo effettuare operazioni quali: calcolare il numero di parole, di caratteri ecc ecc.
Nel codice che hai scritto all'inzio non riesco a capire in base a cosa viene effettuata la divisione in righe del file. C'è il "diverso da null" ma non capisco con cosa viene relazionato.
Inoltre hai scritto \s+ che hai detto ha una funzione particolare. Praticamente, se non ho capito male, splitta il testo ogni qual volta trova il blank (whitespace character). Ne esistono altre di queste espressioni regolari?
grazie.
__________________
Ho felicemente trattato con: Raziel1984,]Rik`[,fab77,pralina,vin81,drago,Qrama,Hangar18,gallo85,kikbond
motogpdesmo16 è offline   Rispondi citando il messaggio o parte di esso
Old 27-12-2005, 20:44   #7
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da motogpdesmo16
Ho creato un piccolo programmino che deve essere alla base di quello che sarà il progetto:
Per le importazioni:
Codice:
import java.lang.*;
import java.io.*;
(al momento penso che ti bastino queste)

Inoltre se in una stringa devi mettere un backslash "\" lo devi raddoppiare "\\" quindi ... FileReader ("c:\\testo.txt");
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 27-12-2005, 21:05   #8
motogpdesmo16
Senior Member
 
Iscritto dal: Feb 2004
Città: Molfetta (BA) Squadra:BARI
Messaggi: 1085
grazie.
Per quanto riguarda il nome file, me ne sono accorto cercando su internet altre informazioni.
__________________
Ho felicemente trattato con: Raziel1984,]Rik`[,fab77,pralina,vin81,drago,Qrama,Hangar18,gallo85,kikbond
motogpdesmo16 è offline   Rispondi citando il messaggio o parte di esso
Old 27-12-2005, 21:15   #9
motogpdesmo16
Senior Member
 
Iscritto dal: Feb 2004
Città: Molfetta (BA) Squadra:BARI
Messaggi: 1085
allora tramite una interfaccia grafica seleziono il file da far analizzare e poi, per l'analisi, lo associo ad un oggetto scanner.
Come si fa a passare come parametro questo oggetto scanner??
Fino ad ora ho scritto questo:
Codice:
import java.io.*;
import java.util.Scanner;
import javax.swing.JFileChooser;
import java.lang.*;



public class textAnalyzer
{
		String nomefile;
		int sommaCar;
		int numero_linee;
		int numero_parole;
		int palindrome;
		
		
		
	private textAnalyzer(String file)
	{
		nomefile="";
		sommaCar=0;
		numero_linee=0;
		numero_parole=0;
		palindrome=0;
	}
	
	
	public int contaCaratteri(InputStream in)
	{
		while (in.hasNextLine())
		{
			String line=in.nextLine();
			sommaCar=sommaCar+line.length();	
					}
	
		return sommaCar;
	}
	
	public int contaLinee(InputStream in)
	{
		while (in.hasNextLine())
		{
			String line=in.nextLine();
			numero_linee++;
		}
	
		return numero_linee;
	}
	

	public static void main (String[] args)	
	{
	
		try
		{
			JFileChooser chooser= new JFileChooser();
			FileReader fr=null;
			if (chooser.showOpenDialog(null)==JFileChooser.APPROVE_OPTION)
			{
				File selectedFile=chooser.getSelectedFile();
				fr=new FileReader(selectedFile);
			}
			
			Scanner in=new Scanner(fr);		
			textAnalyzer testo=new textAnalyzer(in);
			System.out.println ("File" + in + "letto correttamente");
			System.out.println("Numero di caratteri nel file= "+testo.contaCaratteri(in));
			System.out.println("Numero di linee nel file= "+testo.contaLinee(in));
		}
		catch (IOException exception)
		{
				System.out.println ("errore nel file "+exception);
		}
	}
}
Accetto critiche, suggerimenti e soprattutto qualcuno che riesca ad aiutarmi su come far capire ad ogni singolo costruttore (contacaratteri e contalinee) che deve effettuare la scansione sull'oggetto In che a sua volta già contiene il nome del file selezionato.
un'ultima cosa: come mai usando JFileChooser, dopo che appare il messaggio che il file è stato letto correttamente, c'è una successione di caratteri e valorizzazioni che non c'entrano nulla con il programma??Le mette di default quella struttura per caso?
grazie.
__________________
Ho felicemente trattato con: Raziel1984,]Rik`[,fab77,pralina,vin81,drago,Qrama,Hangar18,gallo85,kikbond
motogpdesmo16 è offline   Rispondi citando il messaggio o parte di esso
Old 27-12-2005, 21:20   #10
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da motogpdesmo16
Nel codice che hai scritto all'inzio non riesco a capire in base a cosa viene effettuata la divisione in righe del file. C'è il "diverso da null" ma non capisco con cosa viene relazionato.
Il metodo readLine della classe BufferedReader legge una singola riga dal file. Secondo la documentazione di questo metodo, una riga è considerata terminata quando incontra un line-feed ("\n") oppure un carriage-return ("\r") oppure ancora la sequenza "\r\n".
La documentazione dice anche che viene restituito null se è stata raggiunta la fine del file (EOF).

Quote:
Originariamente inviato da motogpdesmo16
Inoltre hai scritto \s+ che hai detto ha una funzione particolare. Praticamente, se non ho capito male, splitta il testo ogni qual volta trova il blank (whitespace character). Ne esistono altre di queste espressioni regolari?
Beh, sì. Spiegare adesso le espressioni regolari in poche righe non è facile.
La documentazione per le espressioni regolari riconosciute in Java si trova <qui>. Se invece vuoi vedere la cosa un po' più in generale, puoi iniziare da <qui> (è il tutorial sulle regular expressions presente nel "famoso" Java Tutorial).

Piccola nota: le espressioni regolari sono disponibili in molti linguaggi: Java (1.4 in su), PHP, Perl, Python, Javascript, ecc... Tieni presente che tra queste implementazioni ci sono spesso delle piccole differenze nelle varie regole. C'è comunque una base comune.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 27-12-2005, 21:43   #11
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da motogpdesmo16
allora tramite una interfaccia grafica seleziono il file da far analizzare e poi, per l'analisi, lo associo ad un oggetto scanner.
Come si fa a passare come parametro questo oggetto scanner??
Fino ad ora ho scritto questo:
Codice:
...
Ci sono alcune cose non molto chiare: che cosa è la classe "Scanner"?? Poi la classe InputStream non ha dei metodi hasNextLine() e nextLine()!!
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 28-12-2005, 00:39   #12
motogpdesmo16
Senior Member
 
Iscritto dal: Feb 2004
Città: Molfetta (BA) Squadra:BARI
Messaggi: 1085
allora Scanner serve per leggere in input un determinato dato ed è inserita da java5 (se la memoria non mi inganna)in su importando java.util.scanner
Quelle prove inputstream sono delle emerite castronerie, lo ammetto, perchè stavo effettuando delle prove disperate.

Come metodologia comunque penso sia giusta quella di creare vari costruttori a seconda della finalità che mi pongo (calcolare i caratteri, le righe...) anzichè mettere tutto nel calderone del main o peggio, in un unico costruttore.
Inoltre, dato che le operazioni le devo eseguire sempre scansionando il file, mi converrebbe aprirlo una sola volta, magari nel main, e poi effettuare i vari calcoli. Faccio questa operazione con
Codice:
Scanner in=new Scanner(fr);
poi creo l'oggetto
Codice:
textAnalyzer testo=new textAnalyzer(in);
e procedo a chiamare i costruttori..ma cosa ci passo come parametri per far capire che in in c'è il file aperto???
__________________
Ho felicemente trattato con: Raziel1984,]Rik`[,fab77,pralina,vin81,drago,Qrama,Hangar18,gallo85,kikbond
motogpdesmo16 è offline   Rispondi citando il messaggio o parte di esso
Old 28-12-2005, 09:34   #13
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da motogpdesmo16
allora Scanner serve per leggere in input un determinato dato ed è inserita da java5 (se la memoria non mi inganna)in su importando java.util.scanner
Uff ... già è vero. È che io continuo, per i miei sviluppi in Java, ad usare ancora Java 1.4 (quindi l'API reference ce l'ho per la 1.4) e non ho ancora preso confidenza con le (tante) novità del Java 1.5!

Quote:
Originariamente inviato da motogpdesmo16
Quelle prove inputstream sono delle emerite castronerie, lo ammetto, perchè stavo effettuando delle prove disperate.
Ok, anche perché tanto non avrebbe compilato.

Quote:
Originariamente inviato da motogpdesmo16
Come metodologia comunque penso sia giusta quella di creare vari costruttori a seconda della finalità che mi pongo (calcolare i caratteri, le righe...) anzichè mettere tutto nel calderone del main o peggio, in un unico costruttore.
Inoltre, dato che le operazioni le devo eseguire sempre scansionando il file, mi converrebbe aprirlo una sola volta, magari nel main, e poi effettuare i vari calcoli. Faccio questa operazione con
Codice:
Scanner in=new Scanner(fr);
poi creo l'oggetto
Codice:
textAnalyzer testo=new textAnalyzer(in);
e procedo a chiamare i costruttori..ma cosa ci passo come parametri per far capire che in in c'è il file aperto???
Uhm ... forse non ti è molto chiaro. Quelli che tu hai chiamato:
public int contaCaratteri(InputStream in)
e
public int contaLinee(InputStream in)
non sono dei costruttori ma dei semplici metodi!

Comunque anche ammesso che tu usi un InputStream per effettuare una certa operazione (es. conteggio dei caratteri), una volta che hai "consumato" lo stream, prima di effettuare un'altra operazione (es. conteggio delle linee) dovresti o ricreare un altro InputStream o fargli un "rewind" in qualche modo (la InputStream ha due metodi mark() e reset(), io personalmente non li ho mai usati, vedi tu).
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 28-12-2005, 12:38   #14
motogpdesmo16
Senior Member
 
Iscritto dal: Feb 2004
Città: Molfetta (BA) Squadra:BARI
Messaggi: 1085
mi confondo sempre...effettivamente sono dei metodi. Il costruttore è relativo all'oggetto che creo con il nome della classe. Passare di botto da vb e suoi derivati a java è leggermente traumatico....
Tornando in tema..mi conviene dunque aprire il file ogni qual volta entro in un metodo (conta caratteri, conta linee ecc) proprio per evitare casini??
__________________
Ho felicemente trattato con: Raziel1984,]Rik`[,fab77,pralina,vin81,drago,Qrama,Hangar18,gallo85,kikbond
motogpdesmo16 è offline   Rispondi citando il messaggio o parte di esso
Old 28-12-2005, 14:34   #15
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da motogpdesmo16
Tornando in tema..mi conviene dunque aprire il file ogni qual volta entro in un metodo (conta caratteri, conta linee ecc) proprio per evitare casini??
Penso proprio di sì.

Piuttosto, sei sicuro di non poter fare tutto in una sola passata??
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 28-12-2005, 14:59   #16
motogpdesmo16
Senior Member
 
Iscritto dal: Feb 2004
Città: Molfetta (BA) Squadra:BARI
Messaggi: 1085
indubbiamente posso fare tutto in una sola passata.
Trattandosi però di progettino universitario, contavo di effettuare una bella separazione in classi creandone una per ogni richiesta.
Lo so che dal punto di vista funzionale è inutile aprire/chiudere file per ogni operazione e per ogni riga ma temo che, facendo in una sola passata appunto, possa non essere apprezzato anche se, come detto, dal punto di vista delle risorse è sicuramente una soluzione migliore.

Edit: ripensandoci comunque tutte ste cose che ho scritto qui posso scriverle nella relazione da allegare al progetto e quindi giustificare la mia scelta che si andrà ad orientare nella famosa "unica passata":
__________________
Ho felicemente trattato con: Raziel1984,]Rik`[,fab77,pralina,vin81,drago,Qrama,Hangar18,gallo85,kikbond
motogpdesmo16 è offline   Rispondi citando il messaggio o parte di esso
Old 28-12-2005, 15:37   #17
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da motogpdesmo16
Trattandosi però di progettino universitario, contavo di effettuare una bella separazione in classi creandone una per ogni richiesta.
Allora potresti appunto creare una serie di classi es. ContaCaratteri, ContaLinee, ecc... e in ognuna mettere per esempio:
- un costruttore che prende una String con il nome del file.
- un metodo elabora() che apre, legge, conteggia, ecc... e mette i dati in variabili private.
- dei metodi tipo getNumeroCaratteri(), getNumeroLinee(), ecc... per restituire i dati.
Che ti sembra?
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare HP Imagine 2026: abbiamo visto HP IQ all’opera, ...
PNY RTX 5080 Slim OC, sembra una Founders Edition ma non lo è PNY RTX 5080 Slim OC, sembra una Founders Editio...
Wi-Fi 7 con il design di una vetta innevata: ecco il nuovo sistema mesh di Huawei Wi-Fi 7 con il design di una vetta innevata: ecc...
Core Ultra 7 270K Plus e Core Ultra 7 250K Plus: Intel cerca il riscatto ma ci riesce in parte Core Ultra 7 270K Plus e Core Ultra 7 250K Plus:...
PC Specialist Lafité 14 AI AMD: assemblato come vuoi tu PC Specialist Lafité 14 AI AMD: assemblat...
Ex CEO di Intel furioso verso Wall Stree...
Un foglietto di rame e le prestazioni di...
100 agenti AI per dipendente: quello che...
Le 10 migliori offerte del weekend Amazo...
75'' e 85'' QD-Mini LED: 2 TV interessan...
Offerte Amazon sui componenti hardware P...
iOS 27 porterà tante novità...
Tutte le migliori offerte sui robot aspi...
Attenti ai Samsung 990 Pro contraffatti,...
2 prezzi eccezionali: scope elettriche l...
Crimson Desert arriva anche su Switch 2?...
2 iPhone in offerta su Amazon: il 17 256...
Il dodicesimo lancio del razzo spaziale ...
Blue Origin sta assemblando il secondo l...
Meta moltiplica gli investimenti in data...
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: 12:56.


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