Finish Completion Linear.
This commit is contained in:
95
src/ecoparasite/LectureEval.java
Normal file
95
src/ecoparasite/LectureEval.java
Normal file
@@ -0,0 +1,95 @@
|
||||
package ecoparasite;
|
||||
|
||||
import ecoparasite.input.InputFactory;
|
||||
import ecoparasite.input.InputFileException;
|
||||
import ecoparasite.input.RawData;
|
||||
import ecoparasite.input.RawDataOverflow;
|
||||
import ecoparasite.population.Population;
|
||||
import ecoparasite.population.PopulationArgInterval;
|
||||
import ecoparasite.population.PopulationArgs;
|
||||
|
||||
import java.util.HashMap;
|
||||
import java.util.HashSet;
|
||||
|
||||
public class LectureEval {
|
||||
|
||||
public static HashSet<Population> parseEval( RawData popRaw ){
|
||||
|
||||
HashSet<Population> popEspece = new HashSet<>();
|
||||
|
||||
int index = 1;
|
||||
try {
|
||||
while(true){
|
||||
HashMap<String,String> fields = popRaw.getEntry(index);
|
||||
|
||||
String espece = fields.get("Espèce");
|
||||
|
||||
Population population = new Population(espece);
|
||||
|
||||
if( population.getTotal() == null ){
|
||||
population.setTotal( new PopulationArgs() );
|
||||
}
|
||||
for( String k: fields.keySet() ){
|
||||
if( k.equals("Espèce") )
|
||||
continue;
|
||||
|
||||
LectureEval.applyValueForPopEval( population.getTotal(), k, fields.get(k) );
|
||||
}
|
||||
|
||||
popEspece.add(population);
|
||||
index++;
|
||||
}
|
||||
} catch (RawDataOverflow e) {
|
||||
// Fin de la liste.
|
||||
}
|
||||
|
||||
return popEspece;
|
||||
}
|
||||
|
||||
public static void applyValueForPopEval( PopulationArgs popArgs, String column, String value ){
|
||||
|
||||
if( value == null || value == "" ) // On n'ajoute pas les valeurs nulles.
|
||||
return;
|
||||
|
||||
switch (column){
|
||||
case "zone":
|
||||
popArgs.setZone(value);
|
||||
break;
|
||||
case "N":
|
||||
popArgs.setNumber( Integer.parseInt(value) );
|
||||
break;
|
||||
case "Prevalence":
|
||||
popArgs.setPrevalence(PopulationArgInterval.fromString(value));
|
||||
break;
|
||||
case "LT mm":
|
||||
popArgs.setLength(PopulationArgInterval.fromString(value));
|
||||
break;
|
||||
case "Masse g":
|
||||
popArgs.setWidth(PopulationArgInterval.fromString(value));
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
public static void main(String[] args) throws RawDataOverflow {
|
||||
|
||||
RawData popRaw;
|
||||
try {
|
||||
popRaw = InputFactory.readData("test3.csv", "," );
|
||||
} catch(InputFileException e) {
|
||||
System.out.println(e.getMessage());
|
||||
return;
|
||||
}
|
||||
|
||||
HashSet<Population> pop = parseEval(popRaw);
|
||||
|
||||
// System.out.println( popRaw.getEntry(1) );
|
||||
|
||||
for( Population p: pop){
|
||||
System.out.println(p);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user