Digamos que está tratando con algún otro delimitador, tal como una lengüeta \t
, en lugar de una nueva línea \n
.
Un enfoque más general de los delimitadores es el uso de getc()
, que toma un carácter a la vez.
Tenga en cuenta que getc()
devuelve int
, por lo que podemos probar la igualdad con EOF
.
En segundo lugar, definimos un array de tipo line[BUFFER_MAX_LENGTH]
char
, con el fin de almacenar hasta BUFFER_MAX_LENGTH-1
caracteres en la pila (tenemos que salvar lo último carácter de un personaje \0
terminador).
El uso de una matriz evita la necesidad de utilizar malloc
y free
para crear un puntero de carácter de la longitud correcta en el montón.
#define BUFFER_MAX_LENGTH 1024
int main(int argc, char* argv[])
{
FILE *file = NULL;
char line[BUFFER_MAX_LENGTH];
int tempChar;
unsigned int tempCharIdx = 0U;
if (argc == 2)
file = fopen(argv[1], "r");
else {
fprintf(stderr, "error: wrong number of arguments\n"
"usage: %s textfile\n", argv[0]);
return EXIT_FAILURE;
}
if (!file) {
fprintf(stderr, "error: could not open textfile: %s\n", argv[1]);
return EXIT_FAILURE;
}
/* get a character from the file pointer */
while(tempChar = fgetc(file))
{
/* avoid buffer overflow error */
if (tempCharIdx == BUFFER_MAX_LENGTH) {
fprintf(stderr, "error: line is too long. increase BUFFER_MAX_LENGTH.\n");
return EXIT_FAILURE;
}
/* test character value */
if (tempChar == EOF) {
line[tempCharIdx] = '\0';
fprintf(stdout, "%s\n", line);
break;
}
else if (tempChar == '\n') {
line[tempCharIdx] = '\0';
tempCharIdx = 0U;
fprintf(stdout, "%s\n", line);
continue;
}
else
line[tempCharIdx++] = (char)tempChar;
}
return EXIT_SUCCESS;
}
Si tiene que usar un char *
, a continuación, puede seguir utilizando este código, pero strdup()
la matriz line[]
, una vez que se llena con el valor de una línea de entrada. Debe free
esta cadena duplicada una vez que haya terminado con él, o tendrá que obtener una pérdida de memoria:
#define BUFFER_MAX_LENGTH 1024
int main(int argc, char* argv[])
{
FILE *file = NULL;
char line[BUFFER_MAX_LENGTH];
int tempChar;
unsigned int tempCharIdx = 0U;
char *dynamicLine = NULL;
if (argc == 2)
file = fopen(argv[1], "r");
else {
fprintf(stderr, "error: wrong number of arguments\n"
"usage: %s textfile\n", argv[0]);
return EXIT_FAILURE;
}
if (!file) {
fprintf(stderr, "error: could not open textfile: %s\n", argv[1]);
return EXIT_FAILURE;
}
while(tempChar = fgetc(file))
{
/* avoid buffer overflow error */
if (tempCharIdx == BUFFER_MAX_LENGTH) {
fprintf(stderr, "error: line is too long. increase BUFFER_MAX_LENGTH.\n");
return EXIT_FAILURE;
}
/* test character value */
if (tempChar == EOF) {
line[tempCharIdx] = '\0';
dynamicLine = strdup(line);
fprintf(stdout, "%s\n", dynamicLine);
free(dynamicLine);
dynamicLine = NULL;
break;
}
else if (tempChar == '\n') {
line[tempCharIdx] = '\0';
tempCharIdx = 0U;
dynamicLine = strdup(line);
fprintf(stdout, "%s\n", dynamicLine);
free(dynamicLine);
dynamicLine = NULL;
continue;
}
else
line[tempCharIdx++] = (char)tempChar;
}
return EXIT_SUCCESS;
}
Este código no debería ni siquiera compilar. 'sscanf (línea, nombre de archivo,"% s ");' debe ser 'sscanf (línea, archivo,"% s ");' – Mawg
Tenga en cuenta que ['while (! feof (archivo))' siempre es incorrecto] (http : //stackoverflow.com/questions/5431941/while-feof-file-is-always-wrong). –
Posible duplicado de [C leer archivo línea por línea] (https://stackoverflow.com/questions/3501338/c-read-file-line-by-line) –