gpt4 book ai didi

Python到C的转换,将csv的列读入数组

转载 作者:行者123 更新时间:2023-11-30 16:43:12 24 4
gpt4 key购买 nike

我希望逐行读取 csv 文件并将每一列写入 C 中的数组。本质上我想将以下 Python 代码转换为 C:

import csv
date = []
x = []
y = []
with open("file.csv") as old:
read = csv.reader(old,delimiter = ',')
for row in read:
date.append(row[0])
x.append(float(row[1]))
y.append(float(row[2]))

csv文件有128行3列;日期,x,y。我的想法:

char Date[];
int Date[128], i;
for(i = 0; i < 128; i++)
{
Date[i] = x;
}

这是一个简单的示例,我尝试用 for 循环中的值填充数组。我想知道如何修改它以用 csv 文件的每一行填充数组,并用 ',' 分隔符分隔?我想使用 fscanf 函数,但不确定如何将其合并到上述设置中?

尝试:

FILE* f = fopen("file.csv", "r");
fscanf(f, "%char, %f %f", time, &value, &value);

更新:

以下代码读取我的数据的文本文件并输出到屏幕:

#include <stdio.h>

int main(void)
{
char buff[128];
FILE * myfile;

myfile = fopen("File.txt","r");

while (!feof(myfile))
{
fgets(buff,128,myfile);
printf("%s",buff);
}

fclose(myfile);

return 0;
}

我想将每一列存储为数组,而不是输出到屏幕。关于如何做到这一点有什么建议吗?

更新2。

我已更新代码如下:

#include <stdio.h>
#include<string.h>
int main(void)
{
char buff[128];
char * entry;
FILE * myfile;

myfile = fopen("file.txt","r");

while(fgets(buff,128,myfile)){
puts(buffer);
entry = strtok(buff,",");
while(entry!=NULL)
{
printf("%s\n",entry) ;
entry = strtok(NULL,",");
}
}

return 0;
}

最终更新。

我发现了一个例子,它的功能非常相似,而且对我来说更加直观(考虑到我在 C 方面的能力有限)

https://cboard.cprogramming.com/c-programming/139377-confused-parsing-csv-txt-file-strtok-fgets-sscanf.html

更新代码

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

int main()
{

char line[200];
int i = 0;
int x[50];
int y[50];
int z[50];
FILE *myFile;
myFile = fopen("file.txt", "rt");
while(fgets(line, sizeof line, myFile) != NULL)
{

if(sscanf(line, "%d,%d,%d", &x[i], &y[i],&z[i]) == 3)
{
++i;
}
}
//Close the file
fclose(myFile);
getch();

return 0;

}

如果 $x$、$y$ 和 $z$ 是整数/ float ,这段代码对我有用。但是,当 $x$ 是日期时,我无法解析它。日期的格式为 $Year-Month-day-Time$。

我的尝试

我尝试过更改线路

 if(sscanf(line,  "%d,%d,%d",  &x[i], &y[i],&z[i]) == 3)

if(sscanf(line, "%d-%d-%d-%d",&year[i],&month[i], &day[i],&time[i], "%d,%d",   &y[i],&z[i]) == 3)

并声明了新数组

int year, int month, int day, int time

但是,这种方法的输出是垃圾。关于如何修改此代码以正确读取和解析日期有什么建议吗?

最佳答案

您可以使用 strtok 按分隔符分割字符串。

This描述了该功能。它包括一个简单的示例。

每次调用都会给您一个子字符串,以找到分隔符的位置结束。然后,您可以将该子字符串复制到字符串数组中的字符串(最大长度,如果您知道最大长度)(或者您可以有一个指向字符串的指针数组,并在复制到 strlen(子字符串)+ 1(+1 表示 NULL 终止符)。

请注意,strtok 会临时修改现有字符串,因此您必须立即使用它或复制它。如果您只是保存一个指向 strtok 返回内容的指针,那么当您完成 strtok 调用序列时,字符串将恢复为其原始形式,并且您的“子字符串”将不是您所期望的。 (有关解释,请参阅 answer to this question。)

并且,请不要使用 !feof(myfile) 来控制循环的退出。请参阅this post以获得解释。由于BradS在他的评论中给出了替代方案,并且这不是您的主要问题,因此我不会在这里重复他。

<小时/>

好的,看看您的 sscanf 方法和有关日期的问题:

我多次使用过各种 scanf 和 printf 函数;我从来没有在同一个调用中见过两个不同格式的字符串,中间有参数。从函数原型(prototype)来看,这是行不通的。我认为它编译的唯一原因是因为可变参数函数中的变量参数列表没有类型检查。它将简单地忽略这些参数:“%d,%d”,&y[i],&z[i],因为这些是输出参数,与格式字符串中的任何内容都不对应。你可以这样做:

if(sscanf(line, "%d-%d-%d-%d,%d,%d",&year[i],&month[i], &day[i],&time[i],&y[i],&z[i]) == 6)

这包括格式字符串中的所有参数。

此外,您还提到创建这样的数组:

int year, int month, int day, int time

那些不是数组。它们是简单的整数。您可以声明一个数组,如下所示:

int year[MAX_SIZE];

我个人发现 scanf 函数集相当难以处理;如果格式字符串与字符串中的实际情况不太匹配,您将无法得到您期望/需要的内容。这就是我喜欢strtok的原因。但并不是每个人都对此感到满意。它不是最明显或直观的界面。

关于Python到C的转换,将csv的列读入数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45443866/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com