首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >从C中较长的字符串中提取子字符串的最佳方法是什么?

从C中较长的字符串中提取子字符串的最佳方法是什么?
EN

Stack Overflow用户
提问于 2019-05-24 07:07:54
回答 1查看 55关注 0票数 0

我有一个格式化为字符串的文件,后面跟着用空格分隔的一长串浮点数:

字符串(空格)浮动(空间) ..。浮动

字符串(空格)浮动(空间) ..。浮动

字符串(空格)浮动(空间) ..。浮动

每一行的字符串和浮点数将被放入一个结构中,目前我所做的方法是使用fget将每一行存储为字符串,然后增量遍历该字符串,检查空格之间的子字符串,然后将这些字符串转换为浮动,并将它们存储在结构中。

这会变得非常乏味和复杂。有更好的方法吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-05-24 08:04:10

根据要固定或可变的变量数,有两种可能的方法。对于固定数量的浮标,可能的解决办法是:

带有数据的“test_data.txt”文件:

代码语言:javascript
复制
test1 1.41 1.73 2.78 3.14
test2 2.41 2.73 3.78 4.14

读取数据的源文件可能是:

代码语言:javascript
复制
#include <stdio.h>

int main(int argc, char ** argv)
{
        FILE * file = fopen("test_data.txt", "r");
        if (file == NULL)
        {
                printf("Cannot open file.\n");
                return 1;
        }

        char string[32] = { 0 };
        float f1, f2, f3, f4;
        while (feof(file) == 0)
        {
                fscanf(file, "%s %f %f %f %f", string, & f1, & f2, & f3, & f4);
                printf("For string: %s values are:\n\t%f %f %f %f\n", string, f1, f2, f3, f4);
        }

        fclose(file);
        return 0;
}

但是,考虑到您所说的浮标数量是多种多样的,可能的解决方案可能是这样的:

带有数据的“test_data.txt”文件:

代码语言:javascript
复制
test1 1.41 1.73 2.78 3.14
test2 2.41 2.73 3.78 4.14 5.15

读取数据的源文件可能是:

代码语言:javascript
复制
#include <ctype.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

static void remove_trailing_spaces(char ** begin)
{
        while (isspace(** begin))
                ++(* begin);
        return;
}

static void get_string(char ** begin, char * output)
{
        remove_trailing_spaces(begin);

        char * end = * begin;
        while (isalnum(* end))
                ++end;

        strncpy(output, * begin, (int)(end - * begin));
        * begin = end;
        return;
}

static void get_float(char ** begin, float * output)
{
        remove_trailing_spaces(begin);

        char * end;
        * output = strtof(* begin, & end);
        * begin = end;
        return;
}

int main(int argc, char ** argv)
{
        FILE * file = fopen("test_data.txt", "r");
        if (file == NULL)
        {
                printf("Cannot open file\n");
                return 1;
        }

        char buffer[1024] = { 0 };
        char string[32] = { 0 };
        while (feof(file) == 0)
        {
                if (fgets(buffer, 1024, file) != NULL)
                {
                        char * begin = & buffer[0];
                        get_string(& begin, string);
                        printf("For string: %s values are:\n\t", string);

                        while ((feof(file) == 0) && (* begin != '\n'))
                        {
                                float f = 0.0;
                                get_float(& begin, & f);
                                printf("%f ", f);
                        }
                        printf("\n");
                }
        }
        fclose(file);
        return 0;
}

记住,这可能不是最好的解决办法。它只表明,与第一种情况相比,在test_data.txt文件的每一行中改变数据数量的文本文件解析工作要稍微多一点。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56287470

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档