我有一个包含32个二进制数字的文本文件,每个数字在单独的行中,每个数字长8个字符。我想将它们作为字符串存储在mem数组中。

现在,此代码如下所示:

    char mem[32][9];
    char line[9];

    FILE *file_pointer;
    file_pointer = fopen(filename, "r");

    if (file_pointer == NULL) {
        printf("Failed to open file \"%s\"!", filename);
    } else {
        int i = 0;
        while (fgets(line, sizeof line, file_pointer)) {
            memcpy(mem[i], line, 8);
            mem[i][8] = '\0';
            i++;
        }
    }
    fclose(file_pointer);


不幸的是,我仍然在line中得到换行符,因此我的数组无法正确显示。

当我打印阵列时,这是我的控制台:

00      00110100
01

02      01111100
03

04      10011100
05

06      10010101
etc...


我的代码用于打印数组:

for (i = 0; i < 32; i++) {
    if (i >= 10) {
        printf("%d", i);
    } else {
        printf("%c%d", '0', i);
    }
    printf("\t%s\n", mem[i]);
}


我也尝试使用:

strtok(line, "\n");

line[strcspn(line, "\r\n")] = '\0';

最佳答案

有关代码的一些注意事项:


您必须使line更长,以便fgets()可以将'\n'读入line。当前,它将每一行分成8个字节的块和带有换行符的空行。
您应该防止while循环读取数组末尾之外的内容。


这是改进的版本

    char mem[32][9] = { 0 };
    char line[80];

    FILE *file_pointer = fopen(filename, "r");

    if (file_pointer == NULL) {
        fprintf(stderr, "Failed to open file \"%s\"!\n", filename);
    } else {
        int i = 0;
        while (i < 32 && fgets(line, sizeof line, file_pointer)) {
            strncat(mem[i], line, 8);
            i++;
        }
        if (i < 32) {
            fprintf(stderr, "Missing values in file \"%s\": found %d lines\n",
                    filename, i);
        }
        fclose(file_pointer);
    }


您还可以通过以下方式简化打印代码:

    for (int i = 0; i < 32; i++) {
        printf("%02d\t%s\n", i, mem[i]);
    }


请注意,如果确定文件格式,可以通过以下方式简化阅读代码:

    char mem[32][9];
    char line[80];

    FILE *file_pointer = fopen(filename, "r");

    if (file_pointer == NULL) {
        fprintf(stderr, "Failed to open file \"%s\"!\n", filename);
    } else {
        if (fread(mem, 9, 32, fp) != 32) {
            fprintf(stderr, "Missing bytes in file %s\n", filename);
        } else {
            for (int i = 0; i < 32; i++) {
                mem[i][8] = '\0';
            }
        }
        fclose(file_pointer);
    }


您可能还想通过一个简单的循环并使用mem[]中的isxdigit()函数来验证<ctype.h>中的字符串是否恰好包含8个十六进制数字:

            for (int i = 0; i < 32; i++) {
                int j;
                for (j = 0; j < 8; i++) {
                    if (!isxdigit((unsigned char)mem[i][j])
                        break;
                }
                if (j != 8 || mem[i][8] != \n') {
                    fprintf("invalid data on line %d\n", i + 1);
                }
                mem[i][8] = '\0';
            }

关于c - 尾随换行符,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/40665863/

10-12 16:09
查看更多