Jump to content

Ficheiros C++


kikokayon
 Share

Recommended Posts

Bom dia,

Estou com um problema na leitura de uma string de um ficheiro. Para uma string pequena (2 ou 3 palavras) o programa funciona. O problema é quando coloco muitos caracteres..

O que estou a fazer de errado?

Aqui vai o código:

#include<cstdlib>
#include<iostream>
#include<string.h>
#include<stdio.h>

int main(){
    
    FILE *f_string;
    int i;
    f_string = fopen("String.txt", "r");
    
    for(i=1; fscanf(f_string, "%c", &f_string[i]) != EOF;i++){
    printf("%c", f_string[i]);
    }

    system("PAUSE");
    return EXIT_SUCCESS;
}
Link to comment
Share on other sites

Nem sei bem como isso funciona.

Estás a ler os caracteres para a variável do ficheiro. E não precisas de ler caracter a caracter. Isso é bastante lento. Podes usar o fgets para ler logo uma linha inteira. E não te esqueças de fechar o ficheiro com a função fclose. O for neste caso também não parece o mais indicado, podias usar um while.

http://www.cplusplus.com/reference/clibrary/cstdio/fgets/

#include <stdio.h>

int main()
{
   FILE * pFile;
   char mystring [100];

   pFile = fopen ("myfile.txt" , "r");
   if (pFile == NULL) perror ("Error opening file");
   else {
     fgets (mystring , 100 , pFile);
     puts (mystring);
     fclose (pFile);
   }
   return 0;
}

<3 life

Link to comment
Share on other sites

Obrigado pela resposta.

O programa original que colocaste não consegui executar em devc++

Por isso alterei, mas só mostra no ecrã a primeira linha do ficheiro. Se o ficheiro conter mais que uma linha não funciona.

#include<cstdlib>
#include<iostream>
#include<string.h>
#include<stdio.h>

int main(){
    
   FILE * pFile;
   char mystring [100];

   pFile = fopen ("myfile.txt" , "r");
   if (pFile == NULL) perror ("Error opening file");
   else {
     fgets (mystring , 100 , pFile);
     puts (mystring);
     fclose (pFile);
   }
   
    system("PAUSE");
    return EXIT_SUCCESS;
}
Link to comment
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
 Share

×
×
  • Create New...

Important Information

By using this site you accept our Terms of Use and Privacy Policy. We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.