IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

C Discussion :

tester la fin d'un fichier


Sujet :

C

  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    83
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 83
    Par défaut tester la fin d'un fichier
    bonjour,

    j ai besoin de lire des donnee se trouvant dans un fichier .obj se presentnt de cette maniere :

    # XSI Wavefront OBJ Export v3.0
    # File Created: Wed Nov 7 10:49:04 2007
    # XSI Version: 6.02.2007.0613
    o 6.02.2007.0613
    mtllib aircraft.mtl


    # Hierarchy (from self to top father)
    g cylinder

    #begin 62 vertices
    v 0.000000 0.000000 -3.931000
    v 0.000000 -0.000000 3.931000
    v -0.241153 0.000000 -3.931000
    v -0.482306 0.000000 -3.931000
    v -0.482306 -0.000000 3.931000
    v -0.241153 -0.000000 3.931000
    v -0.170521 -0.170521 -3.931000
    v -0.341042 -0.341042 -3.931000 etc...

    #begin 265 normals
    n 535 153 153
    etc...

    #begin 158 Faces
    f 1 2 3
    etc...
    en faisant :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
            objfile = fopen("monFichier.obj", "r");
    	if (objfile == NULL) {
    		printf("error opening .OBJ file\n");
    		exit(EXIT_FAILURE);
    	}
     
    	/* read  material  (.mtl )  */
     
    	char FileMTL[12];
    	fseek(objfile, 127 * sizeof(char), SEEK_SET);
    	fscanf(objfile,"%s ", FileMTL);
    	printf(" materials file : %s \n", FileMTL);
    je peu afficher le point mtl : "aircraft.mtl"
    mai ensuite je n'arrive pas a reprendre la lecture de mon fichier sans "erreurs de segmentation"

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    	while ( fgetc(objfile)!=EOF ){
    		nbVertices=0;
    		nbNormals=0;
    		nbFaces=0;
     
    		fscanf(objfile,"#begin %d vertices", &nbVertices);
    		fscanf(objfile,"#begin %d normals", &nbNormals);	
    		fscanf(objfile,"#begin %d faces", &nbFaces);
     
    		if(nbVertices !=0){
    			printf(" nb vertices : %d \n", nbVertices);
    			*vertices = malloc(nbVertices * sizeof(*vertices));
    			/* read vertices*/
    			for (row = 0; row < nbVertices; row++){
    						fscanf(objfile,"v %f %f %f",  &vertices[row][0], &vertices[row][1],  &vertices[row][2]);
    			}
     
    /*print out vertices to check */
    			for (row = 0; row < nbVertices; row++){
    				for (col = 0; col < 3; col++){
    					printf("%f\t", vertices[row][col]);
    				}
    				printf("\n");
    			}
    		}
     
    		else if(nbNormals !=0){
    			printf(" nb normals : %d \n", nbNormals);
     
    			*normals = malloc(nbNormals * sizeof(*normals));
     
    			/*read NormalsLists */
    			for (row = 0; row < nbNormals; row++){
    				fscanf(objfile, "vn %f %f %f",  &normals[row][0], &normals[row][1],  &normals[row][2]);
     
    			}
     
    			/*print out normalslist to check */
    			for (row = 0; row < nbNormals; row++){
    				for (col = 0; col < 2; col++){
    					printf("%f\t", normals[row][col]);
    				}
    				printf("\n");
    			}
    		}
     
    		else if(nbFaces !=0){
    			*facelist = malloc(nbFaces * sizeof(*facelist));
    			*material = malloc(nbFaces * sizeof(*material));
     
    			/* read facelist*/
    			/* f vector1//normal1 vector2//normal2 vector3//normal3*/
    			for (row = 0; row < nbFaces; row++){
    				fscanf(objfile,"usemtl %s", &material[row]);
     
    			fscanf(objfile,"f %d//%d %d//%d %d//%d", &facelist[row][0], &facelist[row][3], &facelist[row][1], &facelist[row][4], 	&facelist[row][2], &facelist[row][5]);
    				// facelists[no of face][data for face]
    				// data are : [vert1 | vert2 | vert3 | norm1 | norm2 | norm3]
    			}
     
    			/*print out facelist to check */
    			for (row = 0; row < 6; row++){
    				for (col = 0; col < 4; col++)
    					printf("%d\t", facelist[row][col]);
    				printf("\n");
    			}
     
    		}

    ce dernier bout de code et sense lire les vertices /normals /Faces et les stockes dans des tableaux correspondants ...

    je pense que mon test de fin de fichier est mauvais (si je met while(1) la boucle infinie tourne indefiniement sans erreur de segmentation...)

    pouvez vous m'aider a comprendre ?



    avant d essayer de tester la fin du fichier j ai essayer de reprendre la lecture de mes donnee grace a :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    fseek(objfile, 187 * sizeof(char), SEEK_SET); // 187 est la position du  prochain int que je veu lire dans le fichier
    fscanf(objfile,"#begin %d vertices", &nbVertices);
    sans succes :: erreur de segmentation a l execution

  2. #2
    Membre confirmé
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    83
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 83
    Par défaut
    ds e me trompe de forum je deplace vers le forum d entraide en programmation c ...

  3. #3
    Membre éprouvé Avatar de BainE
    Inscrit en
    Mai 2004
    Messages
    1 327
    Détails du profil
    Informations forums :
    Inscription : Mai 2004
    Messages : 1 327
    Par défaut
    bonjour,

    c'est ca que tu cherche a faire ? faq C

  4. #4
    Membre chevronné Avatar de corentin59
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    462
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 462
    Par défaut
    Bonjour

    je trouve que la boucle while est un peu curieuse :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    while ( fgetc(objfile)!=EOF ){
    en effet, fgetc fait "avancer" le pointeur objfile d'un caractère mais tu ne récupères pas ce caractère. Et après, tu accède au fichier comme si la position n'avait pas changé.

    il me semble qu'il serait plus simple de lire le fichier ligne par ligne (on accède qu'une fois au fichier pour une ligne donnée) puis une fois que ta ligne est stockée dans un tableau de char, tu lui fais tous les traitements que tu veux.

  5. #5
    Membre chevronné Avatar de corentin59
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    462
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 462
    Par défaut
    Après une lecture plus approfondie de ton code, voici quelques erreurs que je note :

    1) je crois comprendre que vertices, normals, facelist et material sont des matrices de int. Or, dans ta manière de faire l'allocation, seul la moitié du travail est fait. En effet, par la suite tu cherches à accéder aux termes d'indices 0, 1, 2, ..., n mais tu ne lui as jamais dit qu'il y avait n termes par ligne.

    2) il est absolument nécessaire de faire les vérifications nécessaires après avoir fait une allocation

    3) il serait aussi plus prudent de vérifier aussi la sortie de fscanf

  6. #6
    Modérateur
    Avatar de ToTo13
    Homme Profil pro
    Chercheur en informatique
    Inscrit en
    Janvier 2006
    Messages
    5 793
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : Chercheur en informatique
    Secteur : Santé

    Informations forums :
    Inscription : Janvier 2006
    Messages : 5 793
    Par défaut
    Bonjour,

    petite précision, évite de poster deux fois exactement le même sujet : http://www.developpez.net/forums/sho...d.php?t=441722
    Consignes aux jeunes padawans : une image vaut 1000 mots !
    - Dans ton message respecter tu dois : les règles de rédaction et du forum, prévisualiser, relire et corriger TOUTES les FAUTES (frappes, sms, d'aurteaugrafe, mettre les ACCENTS et les BALISES) => ECRIRE clairement et en Français tu DOIS.
    - Le côté obscur je sens dans le MP => Tous tes MPs je détruirai et la réponse tu n'auras si en privé tu veux que je t'enseigne.(Lis donc ceci)
    - ton poste tu dois marquer quand la bonne réponse tu as obtenu.

Discussions similaires

  1. [Débutant] comment tester la fin d'un fichier Excel ?
    Par xingjing910 dans le forum VB.NET
    Réponses: 1
    Dernier message: 20/06/2012, 15h55
  2. [Débutant] Tester la fin d'écriture sur un fichier
    Par SmileSoft dans le forum MATLAB
    Réponses: 3
    Dernier message: 26/05/2011, 13h42
  3. tester la fin d un fichier
    Par guian dans le forum C
    Réponses: 3
    Dernier message: 13/11/2007, 15h54
  4. tester la fin d'un fichier
    Par guian dans le forum C#
    Réponses: 1
    Dernier message: 13/11/2007, 15h16
  5. Comment tester la fin d'un fichier ?
    Par Teddy dans le forum Delphi
    Réponses: 3
    Dernier message: 25/05/2007, 08h22

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo