Progetto Codice Fiscale Inverso in Java
Codegrind Team•Jul 12 2024
Descrizione del Progetto
In questo progetto, creerai un estrattore di dati personali da un codice fiscale italiano utilizzando Java. Il programma decodificherà le informazioni relative al nome, cognome, data di nascita, sesso e luogo di nascita.
Requisiti
- Librerie Java: Utilizzare le librerie standard di Java.
- Input e Output: Utilizzare la riga di comando per l’input e l’output.
- Decodifica del Codice Fiscale:
- Estrarre le informazioni relative al cognome e al nome.
- Estrarre e decodificare la data di nascita e il sesso.
- Estrarre e decodificare il codice del luogo di nascita.
- Gestione degli Errori: Gestire input non validi.
Struttura del Progetto
codicefiscaleinverso/
├── src/
│ ├── Main.java
│ └── CodiceFiscaleInverso.java
└── README.md
Codice di Esempio
Main.java: Questo file contiene il punto di ingresso dell’applicazione.
public class Main {
public static void main(String[] args) {
if (args.length != 1) {
System.out.println("Utilizzo: java Main <codice_fiscale>");
return;
}
String codiceFiscale = args[0].toUpperCase();
CodiceFiscaleInverso cfi = new CodiceFiscaleInverso(codiceFiscale);
try {
cfi.decodifica();
System.out.println("Cognome: " + cfi.getCognome());
System.out.println("Nome: " + cfi.getNome());
System.out.println("Data di Nascita: " + cfi.getDataNascita());
System.out.println("Sesso: " + cfi.getSesso());
System.out.println("Comune di Nascita: " + cfi.getComune());
} catch (IllegalArgumentException e) {
System.out.println(e.getMessage());
}
}
}
CodiceFiscaleInverso.java: Questo file contiene l’implementazione dell’estrazione dei dati dal codice fiscale.
import java.util.HashMap;
import java.util.Map;
import java.time.LocalDate;
import java.time.format.DateTimeFormatter;
public class CodiceFiscaleInverso {
private String codiceFiscale;
private String cognome;
private String nome;
private LocalDate dataNascita;
private String sesso;
private String comune;
private static final Map<String, String> comuniCodici = new HashMap<>();
private static final Map<Character, Integer> meseCodici = new HashMap<>();
static {
comuniCodici.put("H501", "ROMA");
comuniCodici.put("F205", "MILANO");
// Aggiungi altri comuni e codici qui
meseCodici.put('A', 1);
meseCodici.put('B', 2);
meseCodici.put('C', 3);
meseCodici.put('D', 4);
meseCodici.put('E', 5);
meseCodici.put('H', 6);
meseCodici.put('L', 7);
meseCodici.put('M', 8);
meseCodici.put('P', 9);
meseCodici.put('R', 10);
meseCodici.put('S', 11);
meseCodici.put('T', 12);
}
public CodiceFiscaleInverso(String codiceFiscale) {
if (codiceFiscale == null || codiceFiscale.length() != 16) {
throw new IllegalArgumentException("Codice fiscale non valido");
}
this.codiceFiscale = codiceFiscale;
}
public void decodifica() {
cognome = estraiCognome(codiceFiscale.substring(0, 3));
nome = estraiNome(codiceFiscale.substring(3, 6));
dataNascita = estraiDataNascita(codiceFiscale.substring(6, 11));
sesso = estraiSesso(codiceFiscale.substring(9, 11));
comune = estraiComune(codiceFiscale.substring(11, 15));
}
private String estraiCognome(String codice) {
return codice.replaceAll("[^A-Z]", "");
}
private String estraiNome(String codice) {
return codice.replaceAll("[^A-Z]", "");
}
private LocalDate estraiDataNascita(String codice) {
int anno = Integer.parseInt(codice.substring(0, 2));
char meseChar = codice.charAt(2);
int giorno = Integer.parseInt(codice.substring(3, 5));
if (anno < 40) {
anno += 2000;
} else {
anno += 1900;
}
int mese = meseCodici.getOrDefault(meseChar, 1);
if (giorno > 40) {
giorno -= 40;
}
return LocalDate.of(anno, mese, giorno);
}
private String estraiSesso(String codice) {
int giorno = Integer.parseInt(codice);
return (giorno > 40) ? "F" : "M";
}
private String estraiComune(String codice) {
return comuniCodici.getOrDefault(codice, "Comune sconosciuto");
}
public String getCognome() {
return cognome;
}
public String getNome() {
return nome;
}
public String getDataNascita() {
return dataNascita.format(DateTimeFormatter.ofPattern("dd/MM/yyyy"));
}
public String getSesso() {
return sesso;
}
public String getComune() {
return comune;
}
}
Istruzioni per l’Esecuzione
-
Compilare il Progetto:
javac src/Main.java src/CodiceFiscaleInverso.java -d out
-
Eseguire l’Applicazione:
java -cp out Main <codice_fiscale>
Estensioni Possibili
- Database dei Comuni: Integrare un database completo dei comuni italiani per una maggiore accuratezza.
- Validazione del Codice Fiscale: Implementare ulteriori controlli di validità del codice fiscale.
- Supporto per più lingue: Aggiungere il supporto per più lingue per l’interfaccia utente.