我想重写一个以main(){}开头的程序,以便我可以将它用作函数。 通常,程序期望输入文件是输出文件,并且可选地最多6个参数。 我在命令行中传递它们:
programname --opt1 --op2 --op3 <input file> output file
然后getopt_long (int argc, char *const *argv, const char *shortopts, const struct option *longopts, int *indexptr)
读取程序中的不同参数。
当我想创建一个函数时,我必须将名称main()
交给其他人,让我们说programname()
,除此之外我必须直接传递参数,所以1}
main(int argc, char **argv){}
它变成了例如:
main(int opt1, int opt2, int opt3, FILE *infile, FILE *outfile){}
我的问题是:如何管理输入参数数量的可选性?使用getopt_long
我可以使用--opt1
代替-opt1
进行管理,但getopt_long
只能在主要功能中使用,或者?
我可以以某种方式创建一个没有指定输入数量的函数吗?
感谢您的帮助!
编辑: 现在我尝试用scanf()
从用户那里读取argv一个小例子,你可以尝试例如: 第一次输入: - dd = 2 第二个输入:ok
#include <getopt.h>
void main(){
char **options = (char**) malloc(6*sizeof(char*));
int i;
for(i=0;i<6;i++){
options[i] = (char*) malloc(100*sizeof(char));
}
int argc=1;
printf("%s\n", "insert your options. e.g.: [--ngf=20]");
printf("%s\n", "if finished press [ok]");
scanf("%s",options[argc]);
while (strcmp(options[argc],"ok")!=0){
argc++;
scanf("%s",options[argc]);
}
char **argv = (char**) malloc(argc*sizeof(char*));
for(i=0;i<argc;i++){
argv[i] = (char*) malloc(100*sizeof(char));
}
for(i=0;i<argc;i++){
argv[i] = options[i];
}
/* Process Arguments */
optind = 1;
double aa,bb,cc;
int c, dd;
int option_index = 0;
static struct option long_options[] = {
{"aa", 1, 0, 1},
{"bb", 1, 0, 2},
{"cc", 1, 0, 3},
{"dd", 1, 0, 4},
{0, 0, 0, 0}
};
while ((c = getopt_long(argc,argv,"hgt",
long_options, &option_index)) != -1) {
switch (c) {
case 1: if (sscanf(optarg,"%lg",&aa) != 1)
fun_Stop("incorrect format");
break;
case 2: if (sscanf(optarg,"%lg",&bb) != 1)
fun_Stop("incorrect format ");
break;
case 3: if (sscanf(optarg,"%lg",&cc) != 1)
fun_Stop("incorrect format");
break;
case 4: if (sscanf(optarg,"%i",&dd) != 1)
fun_Stop("incorrect format");
break;
default :
break;
}
}
}
答案 0 :(得分:1)
有几种可能性:
1)你保持接口完好无损。这意味着你必须在调用代码时自己构建argc argv。像这样:
void myfunction(int argc, char **argv);
...
char *arguments[5]={"whatever","--opt1","--opt2","blabla","blablabla"};
myfunction(5,arguments);
你可以像以前一样使用getopt_long。请注意,第一个参数argv [0]是程序的名称(在这种情况下不重要),而不是您的第一个参数,它位于argv [1]中。
或
2)如果您的选项只是二进制开/关事务,您可以将选项定义为可以在位域中组合的常量。像这样:
typedef enum {opt1=1, opt2=2, opt3=4, opt4=8} Opts;
void myfunction(unsigned long opts, char *input, char *output)
{
if(opts&opt1)
printf("Option 1!\n");
...
}
...
myfunction(opt1|opt2,"blabla","blablabla");
这应该取决于32或64种不同选项的架构。
答案 1 :(得分:0)
自己解析argc / argv&gt; o&lt;
if (argc >= 2)
{
for (int i = 1; i < argc; i++)
{
char * const arg = argv[i];
// parse..
}
}
或者,您可以使用Boost.ProgramOptions。 (如果你使用的是C ++)
答案 2 :(得分:0)
已经在argc和argv中完成了。传递给程序的参数数量由操作系统存储在argc(参数计数器)中,然后您可以在argv(参数向量)中获取数据。你不需要做你想做的事情,只需简单一点。