{Access} Transformer table

Lidjeu -  
blux Messages postés 27147 Date d'inscription   Statut Modérateur Dernière intervention   -
Bonjour,

j'ai une table du type

station date ph T° O2 NO2 NO3 etc...
stat1 d1 mes mes mes mes mes
stat2 d1 mes mes mes mes mes
stat1 d2 mes mes mes mes mes
etc...

et je souhaite la transformer en un table du type

station date paramètre mesure
stat1 d1 ph mes
stat1 d1 T° mes
stat1 d1 O2 mes
etc...
stat2 d1 ph mes
etc ...

Après qques recherches, je ne vois pas trop comment faire !!
Merci d'avance pour votre aide !
A voir également:

12 réponses

ndsaerith Messages postés 308 Date d'inscription   Statut Membre Dernière intervention   28
 
Bonjour,

Quels sont les noms des champs de ta table colonnes) et ceux que tu veux ajouter/enlevr?
0
Lidjeu
 
Il n'y a rien à rajouter/enlever, toutes les informations doivent rester ...
Dans ma table d'origine, les différents paramètres constituent chacun une colonne.
Je voudrait qu'ils apparaissent chacun sur une ligne (donc s'il y a par exemple 10 paramètres, j'aurai 10x plus de lignes que dans mon fichier de départ, et 9 colonnes en moins).

Je ne sais pas si je suis claire ...
0
blux Messages postés 27147 Date d'inscription   Statut Modérateur Dernière intervention   3 362
 
Salut,

il faut passer en VBA avec parcours d'un recordset et ajout des infos dans une nouvelle table.
0
Lidjeu
 
Merci, mais je n'ai jamais travaillé en VBA ...
Un petit exemple de code que je pourrait facilement adapter me serait d'un grand secours ....
Encore merci !
0
blux Messages postés 27147 Date d'inscription   Statut Modérateur Dernière intervention   3 362
 
Tu sais programmer dans un langage ?
0

Vous n’avez pas trouvé la réponse que vous recherchez ?

Posez votre question
Lidjeu
 
Je suis scientifique ... je programme en ... Fortran (LOL !).
Tout ça pour dire que j'ai besoin d'une piste (je vais pas étudier l'entièreté du VBA pour ce petit travail), et que à partir de là en général je peux me débrouiller pas essais/erreurs ... je connais la logique mais pas les mots-clés.
0
blux Messages postés 27147 Date d'inscription   Statut Modérateur Dernière intervention   3 362
 
bon, je te prépare un mini-truc.
0
Lidjeu
 
Super !! Merci
0
blux Messages postés 27147 Date d'inscription   Statut Modérateur Dernière intervention   3 362
 
Bon voilà :

https://www.cjoint.com/?cwoYVXO5se

Dans le dessin, on voit mes deux tables exemple, avec les noms que j'ai utilisés.

J'ai juste créé un formulaire avec un bouton nommé Bout_Transpo, et sur le clic du bouton j'ai mis le code qui est en bas de l'image.

Je te copie aussi le code, ça t'évitera de le retaper.

Private Sub Bout_Transpo_Click()
Dim Rs1 As DAO.Recordset
Dim Rs2 As DAO.Recordset
Dim I As Integer
Set Rs1 = CurrentDb.OpenRecordset("T_Mesures_source")
Set Rs2 = CurrentDb.OpenRecordset("T_Mesures_cible", dbOpenTable, dbAppendOnly)
Rs1.MoveFirst
While Not Rs1.EOF
    For I = 2 To Rs1.Fields.Count - 1
        With Rs2
            .AddNew
            Rs2(0) = Rs1(0)
            Rs2(1) = Rs1(1)
            Rs2(2) = Rs1(I).Name
            Rs2(3) = Rs1(I).Value
            .Update
        End With
    Next
    Rs1.MoveNext
Wend
Set Rs1 = Nothing
Set Rs2 = Nothing
End Sub

J'ai testé chez moi, ça marche :-)
0
Lidjeu
 
Ok, super, j'ai reproduit le même schéma et ça marche !
Me reste plus qu'à faire 2-3 adaptations et ça le fera ...
Merci pour ton aide Blux :-D
0
Lidjeu
 
C'est bô, c'est propre, ça fait ce que je voulais ...
Si je peux me permettre d'abuser (sinon je chercherai la solution par moi-même) : j'essaie de mettre, à la place du nom du paramètre, un code unique correspondant au paramètre qui est définit dans une autre table (une table très simple à 2 colonnes : code_param et nom_param).
Enfin pardon si j'abuse, mais merci qd même ...
0
blux Messages postés 27147 Date d'inscription   Statut Modérateur Dernière intervention   3 362
 
Tu remplaces :

Rs2(2) = Rs1(I).Name
par

Rs2(2) = DLookup("Nom_Param", "Nom_de_la_table_très_simple_à_2_colonnes", "Code_Param = '" & Rs1(I).Name & "'")

Ca devrait le faire...
0
Lidjeu
 
Ouaip ! Merci ....
0
Lidjeu
 
Enfin en inversant Code_param et Nom_param mais c'est bon ^^
0
blux Messages postés 27147 Date d'inscription   Statut Modérateur Dernière intervention   3 362
 
Pour moi, le code est la représentation réduite du nom...
0