begin process at 2010 02 10 05:44:27
  Trouver un code source :
 
dans
 
Accueil > 

Code

 > 

Chaîne de caractères

 > GETTOK() - OBTENIR LE NIÈME TOKEN

GETTOK() - OBTENIR LE NIÈME TOKEN


 Information sur la source

Note :
10 / 10 - par 1 personne
10,00 / 10

  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10
Catégorie :Chaîne de caractères Niveau :Débutant Date de création :27/07/2004 Date de mise à jour :27/07/2004 18:07:27 Vu :3 352

Auteur : Hades53

Ecrire un message privé
Commentaire sur cette source (2)
Ajouter un commentaire et/ou une note

 Description

Cette fonction permet d'obtenir le Nième token contenu dans une chaîne de caractère, celui-ci est copié vers un buffer. La fonction retourne l'offset du token copié si celui-ci existe, sinon elle retourne -1.
À noter que les tokens vides ne sont pas pris en compte.

Source

  • #include <stdio.h>
  • int gettok(char *subject, int num, int sep, char *dszt) {
  • char *c, *d; /*deux pointeurs sur subject*/
  • int i = 0, of = 0 , r = 0; bool cont;
  • if (num < 0) { cont = true; num *= -1; } /*si num est négatif*/
  • else cont = false;
  • c = d = subject;
  • /*si il y en a, on pase les séparateurs du début, afin de
  • ne pas retourner un token vide */
  • while (*c == sep) { *c++; of++; } d = c;
  • //tant que le chaine n'est pas parcourue entièrement par c..
  • while (*c) {
  • //si on rencontre le caractère de séparation...
  • if (*c == sep) {
  • i++;
  • if (i == num) {
  • if (!cont) while (d < c) *dszt++ = *d++;
  • else while (*d) *dszt++ = *d++;
  • *dszt = 0;
  • //retourne l'offset du token
  • return of;
  • }
  • //comme d = c, on incrémente of de r qu'on remet à 0
  • while (*c == sep) { *c++; of++; } of += r; r = 0; d = c;
  • }
  • else { c++; r++; }
  • }
  • //c arrivé à la fin de la chaîne, on vérifie si il reste un token...
  • if (d < c) {
  • i++;
  • if (i == num) {
  • while (*d) *dszt++ = *d++;
  • *dszt = 0;
  • return of;
  • }
  • }
  • //le token recherché n'existe pas, on retourne -1
  • return -1;
  • }
  • int main(int argc, char* argv[])
  • {
  • char buff[32];
  • int o = gettok("22:46",2,':',buff);
  • printf("minutes: %s offset: %d\n",buff,o);
  • gettok("Couleur: bleu Prix: 1999 Année: 1996 Desc: Très belle voiture, ayant fait..",
  • -8,32,buff);
  • printf("%s\n",buff);
  • return 0;
  • }
#include <stdio.h>

int gettok(char *subject, int num, int sep, char *dszt) {
	char *c, *d; /*deux pointeurs sur subject*/
	int i = 0, of = 0 , r = 0; bool cont;
	if (num < 0) { cont = true; num *= -1; } /*si num est négatif*/
	else  cont = false;
	c = d = subject;
	/*si il y en a, on pase les séparateurs du début, afin de
	ne pas retourner un token vide */
	while (*c == sep) { *c++; of++; } d = c;
	//tant que le chaine n'est pas parcourue entièrement par c..
	while (*c) {
		//si on rencontre le caractère de séparation...
		if (*c == sep) {
				i++;
				if (i == num) {
					if (!cont) while (d < c) *dszt++ = *d++;
					else while (*d) *dszt++ = *d++;
					*dszt = 0;
					//retourne l'offset du token
					return of;
				}
				//comme d = c, on incrémente of de r qu'on remet à 0
				while (*c == sep) { *c++; of++; } of += r; r = 0; d = c;
		}
		else { c++; r++; }   
	}
	//c arrivé à la fin de la chaîne, on vérifie si il reste un token...
	if (d < c) { 
		i++;
		if (i == num) {
			while (*d)  *dszt++ = *d++;
			*dszt = 0;
			return of;
		}
	}
	//le token recherché n'existe pas, on retourne -1
	return -1;
}

int main(int argc, char* argv[])
{
	char buff[32];
	int o = gettok("22:46",2,':',buff);
	printf("minutes: %s offset: %d\n",buff,o);
	gettok("Couleur: bleu Prix: 1999 Année: 1996 Desc: Très belle voiture, ayant fait..",
		-8,32,buff);
	printf("%s\n",buff);
	return 0;
}

 Conclusion

Si vous voulez copier les caractères qui suivent le token voulu, il faut préfixer le préfixer par un "-".
Ex: gettok("Au revoir et bonne chance !",-4,32,out); copiera dans out la chaîne de caractères "bonne chance !".


 Historique

27 juillet 2004 18:07:27 :
Correction du titre.

 Sources du même auteur

Source avec Zip Source avec une capture MORPIONS AVEC PRISE EN CHARGE RÉSEAU [WIN32]
Source avec Zip Source avec une capture [WIN32] TRIER UNE LISTBOX
LISTE DOUBLEMENT CHAÎNÉE GÉNÉRIQUE AVEC ITÉRATEURS
WILD_MATCH() - SAVOIR SI UN WILDCARD VALIDE UNE CHAÎNE
ISIN,ISWORD

 Sources de la même categorie

Source avec Zip RECHERCHE D'ANNAGRAMMES par Torin
GESTION DE CHAINE DE CARACTÉRE EN C++ AVEC NSTRING par xmustapha
Source avec Zip COMMENTER CODE C <=> ASM (WIN64) par BruNews
Source avec Zip GSTRING - GESTION DES CHAINES DE CARACTÈRES par Neokript
Source avec Zip ANALYSEUR SYNTAXIQUEV(0.1) par kohan95

Commentaires et avis

Commentaire de magic_Nono le 29/07/2004 09:58:37

pense a specifier ce qui pour toi est un token

type xml?

utilise plutot char que int pour le séparateur...

sinon, une chtite faute d'ortho : pase => passe


autrement, pt de vu prog,
*dszt = 0;
prefere : *dszt = NULL;

sinon, po mal l'idée de l'ordre invers

++
Magicalement
Nono.

Commentaire de darkyojimbo2 le 12/02/2005 20:35:04

C'est cool que tu aies fait ce petit code comme ça on peut voir  comment marche notre petit $gettok() qu'on utilise tout le temps dans mIRC.

Bonne idée ;)

 Ajouter un commentaire




Nos sponsors


Sondage...

Comparez les prix

CalendriCode

Février 2010
LMMJVSD
1234567
891011121314
15161718192021
22232425262728

Consulter la suite du CalendriCode

 
Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils.
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés

Google Coop CodeS-SourceS Google Coop CodeS-SourceS
Temps d'éxécution de la page : 0,671 sec (3)

Nous contacter | Annoncer sur CodeS-SourceS | Mentions légales