在C中逐行读取文件,

时间:2018-04-15 08:09:06

标签: c input huffman-code

我一直致力于创建类似于下面的霍夫曼表。 enter image description here

我想要做的是我有一些C代码可以翻译一个字母数组和一个频率数组,我试图现在读取一个文件并转换它的行号文件被翻译成匹配的ASCII码(第32行将转换为ASCII码32)并获取Line的内容。我是C的新手还没有探索过文件,我本来可以使用一些技巧。

  • 加载文件
  • 逐行读取文件并将数字内容分配给数组
  • 抓取#行,然后将其转换为匹配的ASCII码。

如果需要,我可以发布我的代码,但我更加困惑的是抓取文件作为我的输入。

int main(int argc, char* argv[])
{
    char arr[127];
    int freq[127];
    int num_of_line = 127;
    int size = sizeof(arr) / sizeof(arr[0]);
    FILE *fp = fopen("kjvdist.txt","r");
    if(fp == NULL){
        printf("The File Does not exist, Try Again?\n");
        return;
    }
    char *ptr[num_of_line];
    for(int row = 0; row < num_of_line; row++) {
            ptr[row] = malloc(size);/*allocate memory */
            fgets(ptr[row],sizeof(ptr[row]),fp);
            int index = ptr[row];
            char asc = ptr[row];
            arr[index] = asc; /* do operation here on ptr[row] to get equivalent ASCII code */
            for(int col = 0; ptr[row][col] ;col++) {
                if(ptr[row][col]>='0' && ptr[row][col]<='9')//check for alphabets & other also
                    int ascii = ptr[row][col] + 48;
                    /* something like above you need to do */
     }
}

    HuffmanCodes(arr, freq, size);
    return 0;
}

1 个答案:

答案 0 :(得分:0)

如果您希望阅读的文件不是很大,最简单的解决方案可能就是将整个文件读入内存。您可以使用mmap()或使用以下内容自行完成:

fd = open(filename, O_RDONLY, 0);
fstat(fd, &st);
data = malloc(st.st_size + 1);
read(fd, data, st.st_size);
data[st.st_size] = '\0';
close(fd);

然后查看数组data以获取换行符(错误检查留给读者练习)。

lineno = 0;
line = data;
while ((nl = strchr(line, '\n') != NULL) {
    *nl = '\0';
    process(line, ++lineno);
    line = nl + 1;
}