c - 如何从 C 中包含字符串、空格、换行符和整数的文件中仅读取整数

标签 c integer binary-search-tree scanf

我知道这是一个非常微不足道的问题,但我只需要快速帮助。我已经尝试解决这个问题有一段时间了。我想做的只是从具有以下形式的文本文件中读取整数

 8 blah blah
 10 blah blah
 2 blah blah
 3 blah blah

我最终只想获取数字,将它们存储在数组中并将这些数字放入 BST 中。当我的文件只包含数字但不包含指定的文件格式时,我的 BST 工作正常。

不管什么blah,我只想获取数字并将它们存储在数组中。如果我拿出blah's,我就能做到这一点。使用fscanf,我得到了存储第一个数字8的代码,但它停在那里。此外,在此示例中,有四行,但文件中有多少行并不重要。可能是 12 或 6。我怎样才能正确地做到这一点。以下是我解决此问题的拙劣尝试。

 fscanf(instructionFile, "%d", &num);

我也尝试过做类似的事情

 while(!feof(instructionFile)){
  fscanf("%d %s %s", &num, string1, string2);
 }

存储所有内容并仅使用整数,但当我这样做时,我的 BST 不起作用。

最佳答案

使用fgets()获取一行输入,使用sscanf()获取整数。在使用 fscanf() 的示例中,第一次调用将读取 int,并且下一个调用将失败,因为输入流中的下一项不是 >int。每次失败后,错误的输入都会保留在输入流中。通过一次获取一行,您可以在空闲时扫描该行,然后再获取另一行输入。

以下是如何执行此操作的示例。请注意,您不应该使用 feof() 来控制读取循环;相反,使用 fgets() 的返回值。此代码假设一行中的第一个条目是您想要的数据,可能带有前导空格。可以针对稍微复杂的情况修改格式字符串。如果您需要更好地控制行的解析,您还可以使用 strtok()

#include <stdio.h>
#include <stdlib.h>

#define MAX_LINES  100

int main(void)
{
    FILE *fp = fopen("data.txt", "r");
    if (fp == NULL) {
        fprintf(stderr, "Unable to open file\n");
        exit(EXIT_FAILURE);
    }

    char buffer[1000];
    int arr[MAX_LINES];
    size_t line = 0;

    while ((fgets(buffer, sizeof buffer, fp) != NULL)) {
        if (sscanf(buffer, "%d", &arr[line]) != 1) {
            fprintf(stderr, "Line formatting error\n");
            exit(EXIT_FAILURE);
        }
        ++line;
    }

    for (size_t i = 0; i < line; i++) {
        printf("%5d\n", arr[i]);
    }

    fclose(fp);

    return 0;
}

最好在调用 sscanf() 之前添加对空行的检查;现在空行被认为是格式错误的数据。

示例文件的输出:

    8
   10
    2
    3

关于c - 如何从 C 中包含字符串、空格、换行符和整数的文件中仅读取整数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42989512/

相关文章:

c - 如何为 EtherCAT 主站实现字符设备的用户空间实现?

c - 如何判断文件是否在FAT系统上(看是否真的可执行)

java - 编写一个方法来查找两个 BST 之间的公共(public)元素,并将它们插入到第 3 个 BST 中

arrays - 来自返回数组最大值的函数的 C 段错误

c - free(temp) 指针释放链表中的头指针-如何保留指向列表原点的指针

c++ - 将短字符串转换为 32 位整数的最有效方法是什么?

java - 在 Java 中,像 "int"这样的原始数据类型是一个类还是一个对象?

SQL:如果我的最大值是 255,使用 tinyint 而不是 Integer 是否有效?

java - 使用二叉搜索树和哈希创建字典

algorithm - 二叉搜索树 - 搜索范围