Précédent   Forum des professionnels en informatique > Java > Général Java > APIs
APIs Forum sur les API standard et API complémentaires. Avant de poster -> FAQ Java, Les meilleures API Java
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 08/02/2012, 12h53   #1
Membre actif
 
Inscription : février 2007
Messages : 167
Détails du profil
Informations forums :
Inscription : février 2007
Messages : 167
Points : 161
Points : 161
Par défaut poi XSSFCell getStringCellValue valeur nulle

Bonjour,

Novice en java j'utilise poi 3.6 pour manipuler un fichier excel 2010.
Dans un premier temps je lis le contenu des premières cellules d'une ligne.
Une fois la valeur lue je l'affiche.

Mon soucis est qu'une erreur NullPointerException est levée quand le contenu de la cellule est vide.
Ce n'est pas la routine getStringCellValue qui plante mais l'exploitation de la "chaîne" lue.
L'affichage plante, un test == null plante.
En désespoir de cause j'ai codé cela :

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
 
  lo_feuille = lo_xdocument.getSheetAt(1);
  lo_ligne = lo_feuille.getRow(1);
  for (ln_cpt_cellules = 0; ln_cpt_cellules < 28; ln_cpt_cellules++) {
    lo_cellule = lo_ligne.getCell(ln_cpt_cellules);
    try {
      System.out.println("Valeur :" + lo_cellule.getStringCellValue());
    } 
    catch (NullPointerException e) {
      System.out.println("La cellule " + ln_cpt_cellules + " est vide.");
    //  e.printStackTrace();
    }
  }
Ma question est : Comment détecter proprement que la valeur d'une cellule est vide ?
Pouvez vous m'aider s'il vous plaît ?

Pozzo
Pozzo est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 08/02/2012, 14h11   #2
Membre confirmé
 
Avatar de mouss4rs
 
Inscription : janvier 2008
Messages : 764
Détails du profil
Informations forums :
Inscription : janvier 2008
Messages : 764
Points : 253
Points : 253
Bonjour,

voilà ce que je fais:

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
POIFSFileSystem fs = new POIFSFileSystem(new FileInputStream(
							request.getParameter("file")));
					HSSFWorkbook wb = new HSSFWorkbook(fs);
					HSSFSheet sheet = wb.getSheetAt(0);
					HSSFRow row = null;
					HSSFCell cell = null;
					int numLigne = 1;
					int n;
					int num;
					
					

					for (Iterator rowIt = sheet.rowIterator(); rowIt.hasNext();) {
						row = (HSSFRow) rowIt.next();
												//test pour eviter les null

	if (row.getCell(8) != null && row.getCell(9) != null) {...
mouss4rs est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 08/02/2012, 14h31   #3
Membre actif
 
Inscription : février 2007
Messages : 167
Détails du profil
Informations forums :
Inscription : février 2007
Messages : 167
Points : 161
Points : 161
Salut mouss4rs,

Merci je vais tester ça.
J'ai aussi remarqué que la fonction getCellType retourne CELL_TYPE_BLANK sans savoir si cela est pertinent ou pas.

Le null que tu proposes me tente plus

Merci je ferme le post.

Pozzo
Pozzo est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 21h04.


 
 
 
 
Partenaires

Hébergement Web