doob666
Messages postés149Date d'inscriptionvendredi 3 novembre 2006StatutMembreDernière intervention25 janvier 2011
-
11 janv. 2009 à 01:33
cs_wims
Messages postés2466Date d'inscriptionvendredi 23 juillet 2004StatutMembreDernière intervention 1 août 2010
-
12 janv. 2009 à 13:38
Bonjour,
J'aimerais savoir comment on peut récupérer des données commençant par le même item dans une hashtable en une seule fois ?
Je m'explique, j'ai crée ma htable (hmake nick 1000) puis j'ai rentré différents items (hadd -m pseudo1 bla / hadd -m pseudo2 blo /etc etc) et j'aimerais récupérer ces différents items en une seule fois.
J'ai essayé
alias ni {
echo -a $hget(nick,*pseudo*)
}
qui aurais dû me retourner "bla blo" mais ceci ne marche pas.
Merci de votre aide
WorldDMT
Messages postés871Date d'inscriptionjeudi 6 juillet 2006StatutMembreDernière intervention 6 janvier 20121 11 janv. 2009 à 13:31
je ne sais pas ce que tu veu faire
mais si pseudo1 pseudo2 pseudoN depases pas la limite de longeur de variable ça ne marchera pas tres bien j'explique
la longueur de caracteres pour une variable depend de chaque version mIRC
si tu utilise par exp version 6.21 la limite est de 940 caracteres je pense
et la version 6.32 c'est a 4140 caracteres par variable
si ça depace tu aura un msg d'erreur "* /set: line too long...."
tu peux faire comme ça
alias ni {
var %i $1,%x $regsubex($str(x,$hget(nick,0).item),/x/g,$iif(%i isin $hget(nick,\n).item,$hget(nick,$hget(nick,\n).item) $+ $chr(32)))
if (%x) echo -a %x
}
doob666
Messages postés149Date d'inscriptionvendredi 3 novembre 2006StatutMembreDernière intervention25 janvier 2011 11 janv. 2009 à 18:09
Bonsoir,
Ce que je veux faire, c'est retourner les résultat de certaine item dans une htable.Cependant j'ai une quinzaine d'item qui commence par la même chose (pseudo) auquel j'ai rajouté 1,2,3 etc etc chaque item renvoie un résultat différent (pseudo1 bla, pseudo2 blo, pseudo3 = blu) et pour ne pas rallonger la source avec des $hget en cascade, j'aimerais pour voir récupérer ces différent résultat en une seule commande (celle que tu m'as donné fonctionne très bien et corresponds a ce que je veux faire (au passage pourrais tu m'expliquer comment tu as fait (ou me passer un tuto) :x ($regsubex /x/g \n <= je ne comprends pas tout ça))
la longueur de caracteres pour une variable << celà veux dire que pour l'item pseudo1 (par exemple) le résultat ne doit pas dépasser 4140 caractère?
uaip
Messages postés1466Date d'inscriptionmardi 20 février 2007StatutMembreDernière intervention 7 février 2011 11 janv. 2009 à 18:38
Oui mais non. On se doute qu'un pseudo ne dépassera pas 4140 caractères, c'est surtout pour ta variable finale (toutes les concaténations des valeurs des items) qu'il faudra faire gaffe, soit %x dans son code.
Des tutos sur les regexps, il y en a partout. Par exemple ici. Fais gaffe quand même à ne pas lire n'importe quel tuto, mIRC supporte (de manière générale) les PCRE et quelques rares normalisations POSIX (mais les deux ne se mélangent pas).
Pense aussi à checker "réponse acceptée" sur le message de WorldDMT, ça nous évite d'atterir ici pensant aider alors que c'est déjà fait
Cordialement, uaip.
Vous n’avez pas trouvé la réponse que vous recherchez ?
cs_wims
Messages postés2466Date d'inscriptionvendredi 23 juillet 2004StatutMembreDernière intervention 1 août 20101 11 janv. 2009 à 18:55
Il y a des fautes d'inattention ds ton premier post, tu oubli le nom de la table ds tes exemple, mais pas bien grave.
Il n'y a rien qui permette de retourne une chaine de la forme "qqch qqch1 qqch2" qui corresponde a un match sur des nom d'item, donc t'es oblige de faire une boucle pour avoir ca, c'est ce que fait WorldDMT avec un $regsubex (on se demande bien ou il a trouve ca tient), $regsubex permet de remplace qqch ds du text selon une expression reguliere, ca p-e etre utilise pour faire des boucles de ce type, ou ce qui va varie est un nombre...
il utilise $str(x,$hget(nick,0).item) pour avoir une chaine de base de forme "xxxxx" , le nombre de x correspond au nombre d'item ds la table.
le deuxieme parametre est l'expression reguliere, ici /x/, les deux / sont les delimiteur de l'expression, ici on match simplement sur la lettre x, le g signifie qu'on le fait autant de fois que possible (pour faire la boucle donc, sinon ca ne le ferai que pour le premier x)
le troiseme parametre determine par quoi on va remplace chaque match, \n retourne le numero du match, on compare %i au nom de l'item, il utilise isin pour verifie le match, je reviens apres la dessus...
Si le isin est valide, alors n remplace le Nieme x par la valeur du Nieme item, sinon par $null, et le tout colle a un espace, pour avoir la forme "qqch qqch1..."
maintenant, il existe deja des outils de recherche avec les hash table, cad qu'au lieu de faire une boucle sur tout les item et ensuite de faire un isin (qui correspond a un certain type de match du style *truc*) on peut utilise $hfind :
$hfind(table,recherche,N,type)
type c'est la methode de recherche, regarde l'aide sur $hfind pour plus de detail, mais pour exemple ici, toi tu veux tout ce qui match qqch qui commence par "truc" donc niveau wildcard ca donnerai truc* donc $hfind(tablem,pseudo*,0,w) retourne le nombre d'item qui match les item pseudo*.
Ca simplifie un peu le code de WorldDMT :
alias ni return $regsubex($str(x,$hfind($1,$2-*,0,w)),/x/g,$+($hget($1,$hfind($1,$2-*,\n,w)),$chr(32)))
j'ai modifie pour que ca soit en une ligne (plus classe) et tu peux maintenant meme specifie le nom de la table genre :
//echo -a $ni(nick,pseudo)
je pense que tu sais tout la :)
au sujet de la longueur, il parlais de la longueur des chaines de caractere en mirc, qui sont maintenant limite a environ 4100 (ca ne depend pas des version de mirc mais de window, et c'est juste qu'avant cette limite etais a environ 940) mais ne tkt pas trop la dessus, je pense pas que tu puisse depasse 4100 caractere...
WorldDMT
Messages postés871Date d'inscriptionjeudi 6 juillet 2006StatutMembreDernière intervention 6 janvier 20121 12 janv. 2009 à 10:02
salut
Wims: "c'est ce que fait WorldDMT avec un $regsubex (on se demande bien ou il a trouve ca tient)"
c'est pas la premiere fois que je met tu te rappel bien la source statistique des chans ça existe bien là bas et bien avant tu m'avais laissé un commentaire qui etait de ce jare j'avais compris c'est tout :)
mais bon dejà tu a donné un truc avec hfind ça nous donne plus d'info merci ^^
au sujet de la longueur
oui j'ai testé betement avec un code comme celui ci
alias t {
var %x 5000
while (%x) {
set %i %i $+ t
dec %x
}
}
ensuite je tape //echo -a $len(%i)
j'ai testé sur la version 6.21 ça returne 943
et aussi sur la version 6.32/6.35 ça retourne 4144
cs_wims
Messages postés2466Date d'inscriptionvendredi 23 juillet 2004StatutMembreDernière intervention 1 août 20101 12 janv. 2009 à 13:38
Je te dis ça parce que c'est pas super propre de faire une boucle avec des $regsubex comme ça même si c'est plus rapide, moi je l'utilise pour mes propres code.Mais je dis surtout ça parce que je pense que tu as juste vu cette technique qqpart et que tu l'utilise partout maintenant.
Je vois pas pourquoi tu reparles de la longueur des chaine, c'est bon je/on sais ce qu'il en est, depuis la première version de mirc, la limite a tjs été a environ 900~ et depuis longtemps il a été demandé qu'elle soit repoussé, bah ça s'est fait sur la 6.32, point.