使用 strtok() 和 strtod() 从 c 中的命令行中分离出 9 个类型为 double 的数字
Separate 9 numbers of type double from command-line in c with strtok() and strtod()
我有以下带有 -k 参数的命令行界面,如下所示:-k "0.0:-1.0:0.0:-1.0:4.0:-1.0 :0.0:-1.0:0.0"。这些是由 ":" 分隔的 9 个双精度值。我已经设法将第一个双精度值 0.0 与 strtok() 和 strtod() 分开,但我需要所有 9 个值,但我似乎没有找到一种有效的方法来做到这一点。
也许有一个循环,然后将值保存在一个 2x3 数组中,但还没有结果。最后,我必须使用这些数字来处理图像中的像素。请注意,这些是示例数字,用户可以键入从 0 到 255 的任何双精度值。希望有人可以提供一些建议。
下面是我如何设法分离第一个值的代码。我将不胜感激有关如何解决此问题的任何建议,谢谢!
char *kernel_input;
char *end = NULL;
kernel_input = strtok(kArg, ":");
if(kernel_input == 0)
{
/* ERROR */
}
double value_1 = (double) strtod(kernel_input, &end);
你能试试这样的东西吗:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define ARYSIZE 100 // mamimum number of elements
/*
* show usage
*/
void
usage(char *cmd)
{
fprintf(stderr, "usage: %s -k value1:value2:..\n", cmd);
}
/*
* split str, store the values in ary, then return the number of elements
*/
int
parsearg(double *ary, char *str)
{
char *tk; // each token
char *err; // invalid character in str
char delim[] = ":"; // the delimiter
double d; // double value of the token
int n = 0; // counter of the elements
tk = strtok(str, delim); // the first call to strtok()
while (tk != NULL) { // loop over the tokens
d = strtod(tk, &err); // extract the double value
if (*err != '[=10=]') { // *err should be a NUL character
fprintf(stderr, "Illegal character: %c\n", *err);
exit(1);
} else if (n >= ARYSIZE) { // #tokens exceeds the array
fprintf(stderr, "Buffer overflow (#elements should be <= %d)\n", ARYSIZE);
exit(1);
} else {
ary[n++] = d; // store the value in the array
}
tk = strtok(NULL, delim); // get the next token (if any)
}
return n; // return the number of elements
}
int
main(int argc, char *argv[])
{
int i, n;
double ary[ARYSIZE];
if (argc != 3 || strcmp(argv[1], "-k") != 0) {
// validate the argument list
usage(argv[0]);
exit(1);
}
n = parsearg(ary, argv[2]); // split the string into ary
for (i = 0; i < n; i++) { // see the results
printf("[%d] = %f\n", i, ary[i]);
}
}
如果执行编译后的命令例如:
./a.out -k "0.0:-1.0:0.0:-1.0:4.0:-1.0:0.0:-1.0:0.0"
它将输出:
[0] = 0.000000
[1] = -1.000000
[2] = 0.000000
[3] = -1.000000
[4] = 4.000000
[5] = -1.000000
[6] = 0.000000
[7] = -1.000000
[8] = 0.000000
如果您在字符串中输入无效字符,程序将打印一条错误消息并中止。
我有以下带有 -k 参数的命令行界面,如下所示:-k "0.0:-1.0:0.0:-1.0:4.0:-1.0 :0.0:-1.0:0.0"。这些是由 ":" 分隔的 9 个双精度值。我已经设法将第一个双精度值 0.0 与 strtok() 和 strtod() 分开,但我需要所有 9 个值,但我似乎没有找到一种有效的方法来做到这一点。
也许有一个循环,然后将值保存在一个 2x3 数组中,但还没有结果。最后,我必须使用这些数字来处理图像中的像素。请注意,这些是示例数字,用户可以键入从 0 到 255 的任何双精度值。希望有人可以提供一些建议。
下面是我如何设法分离第一个值的代码。我将不胜感激有关如何解决此问题的任何建议,谢谢!
char *kernel_input;
char *end = NULL;
kernel_input = strtok(kArg, ":");
if(kernel_input == 0)
{
/* ERROR */
}
double value_1 = (double) strtod(kernel_input, &end);
你能试试这样的东西吗:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define ARYSIZE 100 // mamimum number of elements
/*
* show usage
*/
void
usage(char *cmd)
{
fprintf(stderr, "usage: %s -k value1:value2:..\n", cmd);
}
/*
* split str, store the values in ary, then return the number of elements
*/
int
parsearg(double *ary, char *str)
{
char *tk; // each token
char *err; // invalid character in str
char delim[] = ":"; // the delimiter
double d; // double value of the token
int n = 0; // counter of the elements
tk = strtok(str, delim); // the first call to strtok()
while (tk != NULL) { // loop over the tokens
d = strtod(tk, &err); // extract the double value
if (*err != '[=10=]') { // *err should be a NUL character
fprintf(stderr, "Illegal character: %c\n", *err);
exit(1);
} else if (n >= ARYSIZE) { // #tokens exceeds the array
fprintf(stderr, "Buffer overflow (#elements should be <= %d)\n", ARYSIZE);
exit(1);
} else {
ary[n++] = d; // store the value in the array
}
tk = strtok(NULL, delim); // get the next token (if any)
}
return n; // return the number of elements
}
int
main(int argc, char *argv[])
{
int i, n;
double ary[ARYSIZE];
if (argc != 3 || strcmp(argv[1], "-k") != 0) {
// validate the argument list
usage(argv[0]);
exit(1);
}
n = parsearg(ary, argv[2]); // split the string into ary
for (i = 0; i < n; i++) { // see the results
printf("[%d] = %f\n", i, ary[i]);
}
}
如果执行编译后的命令例如:
./a.out -k "0.0:-1.0:0.0:-1.0:4.0:-1.0:0.0:-1.0:0.0"
它将输出:
[0] = 0.000000
[1] = -1.000000
[2] = 0.000000
[3] = -1.000000
[4] = 4.000000
[5] = -1.000000
[6] = 0.000000
[7] = -1.000000
[8] = 0.000000
如果您在字符串中输入无效字符,程序将打印一条错误消息并中止。