Précédent   Forum du club des développeurs et IT Pro > Autres langages > Autres langages > Prolog
Prolog Forum d'entraide sur la programmation en langage Prolog. Avant de poster : Cours Prolog
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse
 
Outils de la discussion
Publicité
'
Vieux 20/06/2012, 16h37   #1
jfv.work
Invité régulier
 
Inscription : décembre 2010
Messages : 30
Détails du profil
Informations forums :
Inscription : décembre 2010
Messages : 30
Points : 7
Points : 7
Par défaut règles sur des listes à 2 dimensions

Bonjour, je rencontre un problème concernant des listes à 2 dimensions:

Je récupère une liste à partir d'une requete SQL:

Code :
1
2
3
4
odbc_connect('MYèODBC_LINK',_,[user(root),password(''),alias(db),open(once)]),
findall(L, odbc_query(db,"SELECT * FROM maTable",L),List),
maplist(writeln,List),
odbc_disconnect(db).
cela me retourne donc une liste à 2 dimensions contenant les données issues de la table lue.

maTable contient une colonne id et une colonne label, je reçois donc dans prolog une liste de cette forme.
à présent, je souhaite ajouter des règles du type: SI colonne label="AZERTY" Alors 1 Sinon 0
et ajouter ce résultat en fin de liste, cad obtenir:
[[id1,label1,0],[id1,azerty,1],....... ]

Je prend toute idée.

d'avance merci,

cdt,

jfv
jfv.work est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 21/06/2012, 09h06   #2
Trap D
Rédacteur/Modérateur
 
Avatar de Trap D
 
Inscription : septembre 2003
Messages : 4 437
Détails du profil
Informations forums :
Inscription : septembre 2003
Messages : 4 437
Points : 5 301
Points : 5 301
Un simple maplist devrait suffire ,
Code :
1
2
3
4
5
6
maplist(modif, List, L1),
writeln(L1).

modif([A, azerty], [A, azerty,1]).

modif([A, B], [A, B, 0]).
__________________
"La haine seule fait des choix" - Koan Zen
"Il ne faut pas être meilleur que les autres, il faut être meilleur que soi." Albert Jacquard
"Ceux qui savent où ils ont posé leur parapluie ne sont pas alcooliques." - pgibonne.
Faites du Prolog, ça vous changera les idées !
Ma page Prolog
Mes codes sources commentés

Mon avatar : Intérieur avec jeune femme de Vilhelm Hammershoi
Trap D est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 21/06/2012, 10h42   #3
jfv.work
Invité régulier
 
Inscription : décembre 2010
Messages : 30
Détails du profil
Informations forums :
Inscription : décembre 2010
Messages : 30
Points : 7
Points : 7
bonjour et merci de ta réponse,

je comprend bien la logique, mais à la mise en oeuvre avec:

Code :
1
2
3
4
test(List) :- maplist(modif,List,L1), write(L1).

modif([A,azerty],[A,azerty,1]).
modif([A,B],[A,B,0]).
et avec un appel
ou
la réponse est , je pense que ça ne doit pas etre loin.

merci pour vos suggestions,

cdt,

jfv.work
jfv.work est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 21/06/2012, 10h49   #4
Trap D
Rédacteur/Modérateur
 
Avatar de Trap D
 
Inscription : septembre 2003
Messages : 4 437
Détails du profil
Informations forums :
Inscription : septembre 2003
Messages : 4 437
Points : 5 301
Points : 5 301
Oui, la liste d'appel à modif est de la forme [[...], [..], ..], donc pour un élément c'est test([[aaa,azerty]]).
__________________
"La haine seule fait des choix" - Koan Zen
"Il ne faut pas être meilleur que les autres, il faut être meilleur que soi." Albert Jacquard
"Ceux qui savent où ils ont posé leur parapluie ne sont pas alcooliques." - pgibonne.
Faites du Prolog, ça vous changera les idées !
Ma page Prolog
Mes codes sources commentés

Mon avatar : Intérieur avec jeune femme de Vilhelm Hammershoi
Trap D est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 21/06/2012, 11h40   #5
jfv.work
Invité régulier
 
Inscription : décembre 2010
Messages : 30
Détails du profil
Informations forums :
Inscription : décembre 2010
Messages : 30
Points : 7
Points : 7
effectivement, c'est donc que odbc ne me fournit probablement pas une liste à 2 dimensions
jfv.work est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 21/06/2012, 11h51   #6
Trap D
Rédacteur/Modérateur
 
Avatar de Trap D
 
Inscription : septembre 2003
Messages : 4 437
Détails du profil
Informations forums :
Inscription : septembre 2003
Messages : 4 437
Points : 5 301
Points : 5 301
La question est donc "que te fournit odbc ? " : quel est le résultat de maplist(writeln,List) ?
__________________
"La haine seule fait des choix" - Koan Zen
"Il ne faut pas être meilleur que les autres, il faut être meilleur que soi." Albert Jacquard
"Ceux qui savent où ils ont posé leur parapluie ne sont pas alcooliques." - pgibonne.
Faites du Prolog, ça vous changera les idées !
Ma page Prolog
Mes codes sources commentés

Mon avatar : Intérieur avec jeune femme de Vilhelm Hammershoi
Trap D est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 21/06/2012, 12h05   #7
jfv.work
Invité régulier
 
Inscription : décembre 2010
Messages : 30
Détails du profil
Informations forums :
Inscription : décembre 2010
Messages : 30
Points : 7
Points : 7
ça affiche un row(champ1,champ2,.....)

ce sont bien des ( ) et pas des []
jfv.work est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 21/06/2012, 13h19   #8
Trap D
Rédacteur/Modérateur
 
Avatar de Trap D
 
Inscription : septembre 2003
Messages : 4 437
Détails du profil
Informations forums :
Inscription : septembre 2003
Messages : 4 437
Points : 5 301
Points : 5 301
Ok. pour récuperer la liste des champs il suffit de faire
Code :
row(Champ1,Champ2...) =.. [A|B].
Par exemple
Citation:
?- row(Champ1,Champ2) =.. [A|B].
A = row,
B = [Champ1,Champ2].
__________________
"La haine seule fait des choix" - Koan Zen
"Il ne faut pas être meilleur que les autres, il faut être meilleur que soi." Albert Jacquard
"Ceux qui savent où ils ont posé leur parapluie ne sont pas alcooliques." - pgibonne.
Faites du Prolog, ça vous changera les idées !
Ma page Prolog
Mes codes sources commentés

Mon avatar : Intérieur avec jeune femme de Vilhelm Hammershoi
Trap D est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 21/06/2012, 13h48   #9
jfv.work
Invité régulier
 
Inscription : décembre 2010
Messages : 30
Détails du profil
Informations forums :
Inscription : décembre 2010
Messages : 30
Points : 7
Points : 7
reprennons, on a :
odbc_connect('MYèODBC_LINK',_,[user(root),password(''),alias(db),open(once)]),
findall(L, odbc_query(db,"SELECT * FROM maTable",L),List),
maplist(writeln,List),
odbc_disconnect(db).

qui affiche row(champ1,champ2)

on a :
row(Champ1,Champ2) =.. [A|B].,
qui à partir de row(Champ1,Champ2) nous donne [Champ1,Champ2]

on a :
maplist(modif, List, L1),
writeln(L1).
modif([A, azerty], [A, azerty,1]).
modif([A, B], [A, B, 0]).
.
qui va ajouter un champ en fin de ligne tel que si le 2nd champ vaut azerty alors 1 sinon 0 et afficher le résultat.

maintenant il faut emboiter tout ça, et je comprend pas comment dans la partie

odbc_connect('MYèODBC_LINK',_,[user(root),password(''),alias(db),open(once)]),
findall(L, odbc_query(db,"SELECT * FROM maTable",L),List),
maplist(writeln,List),
odbc_disconnect(db).


forcer ce que qualifirai de "conversion" par l'appel de row(Champ1,Champ2) =.. [A|B].

la suite consistant à appeler modif via un maplist est ok
jfv.work est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 21/06/2012, 14h09   #10
Trap D
Rédacteur/Modérateur
 
Avatar de Trap D
 
Inscription : septembre 2003
Messages : 4 437
Détails du profil
Informations forums :
Inscription : septembre 2003
Messages : 4 437
Points : 5 301
Points : 5 301
Première chose , ça évite les lignes de couleur !
Deuxièmement, si j'ai bien compris ton code donne :
Code :
1
2
3
4
5
6
7
odbc_connect('MYèODBC_LINK',_,[user(root),password(''),alias(db),open(once)]),
findall(L, odbc_query(db,"SELECT * FROM maTable",L),List),
% on ferme tout de suite la base de donnee
odbc_disconnect(db).
% maplist(writeln,List), <== inutile
maplist(modif, List, L1),
maplist(writeln, L1).
avec
Code :
1
2
3
4
5
6
modif(In, Out) :-
  In =.. [_|A], % <== on n'a pas besoin du nom du foncteur
  modifie(A, Out).

modifie([A, azerty], [A, azerty,1]).
modifie([A, B], [A, B, 0]). .
Je peux pas tester mais ça doit fonctionner.
__________________
"La haine seule fait des choix" - Koan Zen
"Il ne faut pas être meilleur que les autres, il faut être meilleur que soi." Albert Jacquard
"Ceux qui savent où ils ont posé leur parapluie ne sont pas alcooliques." - pgibonne.
Faites du Prolog, ça vous changera les idées !
Ma page Prolog
Mes codes sources commentés

Mon avatar : Intérieur avec jeune femme de Vilhelm Hammershoi
Trap D est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 21/06/2012, 14h35   #11
jfv.work
Invité régulier
 
Inscription : décembre 2010
Messages : 30
Détails du profil
Informations forums :
Inscription : décembre 2010
Messages : 30
Points : 7
Points : 7
super, ça marche très bien,

encore merci
jfv.work est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Cette discussion est résolue.
Outils de la discussion

Navigation rapide


Fuseau horaire GMT +2. Il est actuellement 22h34.


 
 
 
 
Partenaires

Hébergement Web