如何使用 CAPL 读取 csv 中的浮点数?
How to read a float in a csv with CAPL?
我有一个 .csv 文件,我想读取其格式的数据,而不是字符串。
如果可以的话,这是将文件保存在读取缓冲区中的功能。
fileGetString(readbuffer,elcount(readbuffer),readHandle)!=0)
我的数据是这种格式的:
Temperature;12.25;15.65;-25.12;80;
Time;1;2;4;7;
我想将温度保存在缓冲区“Temperature[i]
”
对时间“Time[i]
”做同样的事情
我如何在 CAPL 中执行此操作?
我知道我可以像字符串一样读取每个数据并转换为整数或浮点数来执行一些操作,但我想优化代码并以其格式读取每个数据。
您可以使用 strtod()
将字符串转换为浮点数。
只是为了好玩,这里是完整的例子:
on start
{
dword fh;
char text[255];
double Temperature[4], Time[4];
int i;
/* open file */
fh = openFileRead("a.csv",0);
if (!fh) {
write ("ERROR: Open file failed!");
return;
}
/* read the 'Temperature' line */
if (!fileGetString(text, elcount(text), fh) ||
strstr(text, "Temperature;") != 0) {
write("ERROR: Wrong file format, 'Temperature' not found!");
return;
}
/* get the 'Temperature' values */
getValuesFromCsvString(text, Temperature);
/* read the 'Time' line */
if (!fileGetString(text, elcount(text), fh) ||
strstr(text, "Time;") != 0) {
write("ERROR: Wrong file format, 'Time' not found!");
return;
}
/* get the 'Time' values */
getValuesFromCsvString(text, Time);
/* output values */
for (i = 0; i < elcount(Temperature); i++)
write("Temperature[%i] = %6.2f", i, Temperature[i]);
for (i = 0; i < elcount(Time); i++)
write("Time[%i] = %2.0f", i, Time[i]);
}
int getValuesFromCsvString(char text[], double vals[])
{
long i, pos;
double res;
pos = strstr(text, ";");
str_replace(text, ";", " ");
for (i = 0; i < elcount(vals) ; i++) {
pos = strtod(text, pos, res);
if (pos >= 0)
vals[i] = res;
else
break;
}
return 0;
}
输出:
Temperature[0] = 12.25
Temperature[1] = 15.65
Temperature[2] = -25.12
Temperature[3] = 80.00
Time[0] = 1
Time[1] = 2
Time[2] = 4
Time[3] = 7
我有一个 .csv 文件,我想读取其格式的数据,而不是字符串。 如果可以的话,这是将文件保存在读取缓冲区中的功能。
fileGetString(readbuffer,elcount(readbuffer),readHandle)!=0)
我的数据是这种格式的:
Temperature;12.25;15.65;-25.12;80;
Time;1;2;4;7;
我想将温度保存在缓冲区“Temperature[i]
”
对时间“Time[i]
”做同样的事情
我如何在 CAPL 中执行此操作?
我知道我可以像字符串一样读取每个数据并转换为整数或浮点数来执行一些操作,但我想优化代码并以其格式读取每个数据。
您可以使用 strtod()
将字符串转换为浮点数。
只是为了好玩,这里是完整的例子:
on start
{
dword fh;
char text[255];
double Temperature[4], Time[4];
int i;
/* open file */
fh = openFileRead("a.csv",0);
if (!fh) {
write ("ERROR: Open file failed!");
return;
}
/* read the 'Temperature' line */
if (!fileGetString(text, elcount(text), fh) ||
strstr(text, "Temperature;") != 0) {
write("ERROR: Wrong file format, 'Temperature' not found!");
return;
}
/* get the 'Temperature' values */
getValuesFromCsvString(text, Temperature);
/* read the 'Time' line */
if (!fileGetString(text, elcount(text), fh) ||
strstr(text, "Time;") != 0) {
write("ERROR: Wrong file format, 'Time' not found!");
return;
}
/* get the 'Time' values */
getValuesFromCsvString(text, Time);
/* output values */
for (i = 0; i < elcount(Temperature); i++)
write("Temperature[%i] = %6.2f", i, Temperature[i]);
for (i = 0; i < elcount(Time); i++)
write("Time[%i] = %2.0f", i, Time[i]);
}
int getValuesFromCsvString(char text[], double vals[])
{
long i, pos;
double res;
pos = strstr(text, ";");
str_replace(text, ";", " ");
for (i = 0; i < elcount(vals) ; i++) {
pos = strtod(text, pos, res);
if (pos >= 0)
vals[i] = res;
else
break;
}
return 0;
}
输出:
Temperature[0] = 12.25
Temperature[1] = 15.65
Temperature[2] = -25.12
Temperature[3] = 80.00
Time[0] = 1
Time[1] = 2
Time[2] = 4
Time[3] = 7