def application_Vacance(self, dataset): donnees_covid = dataset.donnees_covid.liste donnees_vacance = dataset.donnees_vacances indice_dep = donnees_covid[0].index("dep") indice_jour = donnees_covid[0].index("jour") indice_selection = donnees_covid[0].index(self.var_selection) new_dataset = Dataset( Covid(None, [ donnees_covid[0][indice_dep], donnees_covid[0][indice_jour], self.var_jointure, self.var_selection ]), donnees_vacance) endroit = None if self.var_jointure in donnees_vacance['Academie'][ 0] and self.var_jointure in donnees_vacance['Calendrier'][0]: endroit = 'Academie' elif self.var_jointure in donnees_vacance['Calendrier'][0]: endroit = 'Calendrier' elif self.var_jointure in donnees_vacance['Academie'][0]: endroit = 'Academie' else: print( "La variable recherchée n'est pas présente. Revoyez l'écriture ou les données" ) for i in range(1, len(donnees_covid)): pos = 0 if donnees_covid[i][indice_dep] == '2A': while not donnees_vacance['Academie'][pos][ "Code_Dpt"] == '2A' and pos < ( len(donnees_vacance['Academie']) - 1): pos += 1 elif donnees_covid[i][indice_dep] == '2B': while not donnees_vacance['Academie'][pos][ "Code_Dpt"] == '2B' and pos < ( len(donnees_vacance['Academie']) - 1): pos += 1 else: while not float(donnees_vacance['Academie'][pos]["Code_Dpt"] ) == donnees_covid[i][indice_dep] and pos < ( len(donnees_vacance['Academie']) - 1): pos += 1 new_dataset.ajout_donnees_covid([ donnees_covid[i][indice_dep], donnees_covid[i][indice_jour], donnees_vacance[endroit][pos][self.var_jointure], donnees_covid[i][indice_selection] ]) return (new_dataset.donnees_covid.liste)
def application_Covid(self, dataset): donnees_covid = dataset.donnees_covid.liste donnees_covid2 = self.dataset2.donnees_covid.liste indice_jour = donnees_covid[0].index("jour") indice_jour2 = donnees_covid2[0].index("jour") indice_sexe = None if "reg" in donnees_covid[0]: indice_spatial = donnees_covid[0].index("reg") elif "dep" in donnees_covid[0]: indice_spatial = donnees_covid[0].index("dep") elif "numReg" in donnees_covid[0]: indice_spatial = donnees_covid[0].index("Numreg") if 'sexe' in donnees_covid[0]: indice_sexe = donnees_covid[0].index("sexe") if self.var_selection in donnees_covid[0]: indice1 = donnees_covid[0].index(self.var_selection) elif self.var_jointure in donnees_covid[0]: indice1 = donnees_covid[0].index(self.var_jointure) if self.var_selection in donnees_covid2[0]: indice2 = donnees_covid2[0].index(self.var_selection) elif self.var_jointure in donnees_covid2[0]: indice2 = donnees_covid2[0].index(self.var_jointure) new_dataset = Dataset( Covid(None, [[ donnees_covid[0][indice_spatial], donnees_covid2[0][indice_jour2], donnees_covid[0][indice1], donnees_covid2[0][indice2] ]]), dataset.donnees_vacances) new_dataset.donnees_covid.append() pos = 1 i = 1 if len(donnees_covid) >= len( donnees_covid2): #il y a plus de jours dans donnees_covid if indice_sexe == None: while i < len(donnees_covid) and pos < (len(donnees_covid2)): if donnees_covid[i][indice_jour] == donnees_covid2[pos][ indice_jour2]: new_dataset.ajout_donnees_covid([ donnees_covid[i][indice_spatial], donnees_covid2[pos][indice_jour2], donnees_covid[i][indice1], donnees_covid2[pos][indice2] ]) i += 1 pos += 1 else: i += 1 else: while i < len(donnees_covid) and pos < (len(donnees_covid2)): if donnees_covid[i][indice_jour] == donnees_covid2[pos][ indice_jour2]: new_dataset.ajout_donnees_covid([ donnees_covid[i][indice_spatial], donnees_covid2[pos][indice_jour2], donnees_covid[i][indice1], donnees_covid2[pos][indice2] ]) i += 3 pos += 1 else: i += 3 else: if indice_sexe == None: while i < len(donnees_covid2) and pos < (len(donnees_covid2)): if donnees_covid2[i][indice_jour2] == donnees_covid[pos][ indice_jour]: new_dataset.ajout_donnees_covid([ donnees_covid[pos][indice_spatial], donnees_covid[pos][indice_jour2], donnees_covid[pos][indice1], donnees_covid2[i][indice2] ]) i += 1 pos += 1 else: i += 1 else: while i < len(donnees_covid) and pos < (len(donnees_covid2)): if donnees_covid2[i][indice_jour2] == donnees_covid[pos][ indice_jour]: new_dataset.ajout_donnees_covid([ donnees_covid[pos][indice_spatial], donnees_covid[pos][indice_jour2], donnees_covid[pos][indice1], donnees_covid2[i][indice2] ]) i += 3 pos += 1 else: i += 3 return (new_dataset)
def application_regionale(self, dataset): var_dataset = (Selection_Var( self.var_selection, 'covid').application(dataset)).donnees_covid.liste liste_region = self.reg() donnees_covid = dataset.donnees_covid.liste somme = 0 indice_jour = donnees_covid[0].index("jour") indice_dep = donnees_covid[0].index("dep") if 'sexe' in dataset.donnees_covid.liste[0]: indice0, indice1, indice2 = self.sexe(dataset) somme0 = 0 somme1 = 0 somme2 = 0 difference1 = indice1 - indice0 difference2 = indice2 - indice0 difference = indice2 - indice0 + 1 ind_bon_dep = None new_dataset = Dataset( Covid(None, [["Region", 'jour', "sexe", self.var_selection]]), dataset.donnees_vacances) new_jour = donnees_covid[1][indice_jour] for region in liste_region: pos0 = indice0 while pos0 < (len(var_dataset) - difference): jour = donnees_covid[pos0][indice_jour] while jour == new_jour and pos0 < (len(var_dataset) - difference): if donnees_covid[pos0][indice_dep] in region: somme0 += var_dataset[pos0][0] somme1 += var_dataset[pos0 + difference1][0] somme2 += var_dataset[pos0 + difference2][0] ind_bon_dep = pos0 pos0 += difference new_jour = donnees_covid[pos0][indice_jour] else: pos0 += difference new_jour = donnees_covid[pos0][indice_jour] if ind_bon_dep != None: new_dataset.ajout_donnees_covid([ region[0], donnees_covid[pos0][indice_jour], float(0), somme0 ]) new_dataset.ajout_donnees_covid([ region[0], donnees_covid[pos0 + difference1][indice_jour], float(1), somme1 ]) new_dataset.ajout_donnees_covid([ region[0], donnees_covid[pos0 + difference2][indice_jour], float(2), somme2 ]) ind_bon_dep = None somme0 = 0 somme1 = 0 somme2 = 0 pos0 += difference else: new_dataset = Dataset( Covid(None, [["Region", 'jour', self.var_selection]]), dataset.donnees_vacances) somme = 0 i = 1 new_jour = donnees_covid[i][indice_jour] ind_bon_dep = None for region in liste_region: i = 1 while i < len(var_dataset) - 1: jour = donnees_covid[i][indice_jour] while jour == new_jour and i < len(var_dataset) - 1: if donnees_covid[i][indice_dep] in region: somme += var_dataset[i][0] ind_bon_dep = i i += 1 new_jour = donnees_covid[i][indice_jour] else: i += 1 new_jour = donnees_covid[i][indice_jour] if ind_bon_dep != None: new_dataset.ajout_donnees_covid([ region[0], donnees_covid[ind_bon_dep][indice_jour], somme ]) ind_bon_dep = None somme = 0 i += 1 return (new_dataset.donnees_covid.liste)
def application_nationale(self, dataset): var_dataset = (Selection_Var( self.var_selection, 'covid').application(dataset)).donnees_covid.liste donnees_covid = dataset.donnees_covid.liste somme = 0 indice_jour = donnees_covid[0].index("jour") if "sexe" in donnees_covid[0]: indice0, indice1, indice2 = self.sexe(dataset) somme0 = var_dataset[indice0][0] somme1 = var_dataset[indice2][0] somme2 = var_dataset[indice2][0] difference1 = indice1 - indice0 difference2 = indice2 - indice0 difference = indice2 - indice0 + 1 pos0 = indice0 + difference new_dataset = Dataset( Covid(None, [["Nationale", 'jour', 'sexe', self.var_selection]]), dataset.donnees_vacances) while pos0 < len(var_dataset) - difference: if donnees_covid[pos0][indice_jour] == donnees_covid[ pos0 - difference][indice_jour]: somme0 += var_dataset[pos0][0] somme1 += var_dataset[pos0 + difference1][0] somme2 += var_dataset[pos0 + difference2][0] pos0 += difference else: new_dataset.ajout_donnees_covid([ "France", donnees_covid[pos0][indice_jour], float(0), somme0 ]) new_dataset.ajout_donnees_covid([ "France", donnees_covid[pos0 + difference1][indice_jour], float(1), somme1 ]) new_dataset.ajout_donnees_covid([ "France", donnees_covid[pos0 + difference2][indice_jour], float(2), somme2 ]) somme0 = var_dataset[pos0][0] somme1 = var_dataset[pos0 + difference1][0] somme2 = var_dataset[pos0 + difference2][0] pos0 += difference else: new_dataset = Dataset( Covid(None, [["Nationale", 'jour', self.var_selection]]), dataset.donnees_vacances) somme = var_dataset[1][0] i = 2 while i < len(var_dataset): if donnees_covid[i][indice_jour] == donnees_covid[ i - 1][indice_jour]: somme += var_dataset[i][0] i += 1 else: new_dataset.ajout_donnees_covid( ["France", donnees_covid[i][indice_jour], somme]) somme = var_dataset[i][0] i += 1 return (new_dataset.donnees_covid.liste)