Передача аргументов в программу C из командной строки
Итак, я нахожусь в Linux, и я хочу, чтобы аргументы программы принимали при выполнении из командной строки.
Например,
./myprogram 42 -b -s
Итак, тогда программа сохранит это число 42 как int и выполнит определенные части кода в зависимости от того, какие аргументы он получает как -b или -s.
Ответы
Ответ 1
Вы можете использовать getopt.
#include <ctype.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
int
main (int argc, char **argv)
{
int bflag = 0;
int sflag = 0;
int index;
int c;
opterr = 0;
while ((c = getopt (argc, argv, "bs")) != -1)
switch (c)
{
case 'b':
bflag = 1;
break;
case 's':
sflag = 1;
break;
case '?':
if (isprint (optopt))
fprintf (stderr, "Unknown option `-%c'.\n", optopt);
else
fprintf (stderr,
"Unknown option character `\\x%x'.\n",
optopt);
return 1;
default:
abort ();
}
printf ("bflag = %d, sflag = %d\n", bflag, sflag);
for (index = optind; index < argc; index++)
printf ("Non-option argument %s\n", argv[index]);
return 0;
}
Ответ 2
В C это делается с использованием аргументов, переданных вашей функции main()
:
int main(int argc, char *argv[])
{
int i = 0;
for (i = 0; i < argc; i++) {
printf("argv[%d] = %s\n", i, argv[i]);
}
return 0;
}
Более подробную информацию можно найти в Интернете, например Аргументы к главной статье.
Ответ 3
Рассмотрите возможность использования getopt_long()
. Он позволяет использовать как короткие, так и длинные варианты в любой комбинации.
#include <stdio.h>
#include <stdlib.h>
#include <getopt.h>
/* Flag set by `--verbose'. */
static int verbose_flag;
int
main (int argc, char *argv[])
{
while (1)
{
static struct option long_options[] =
{
/* This option set a flag. */
{"verbose", no_argument, &verbose_flag, 1},
/* These options don't set a flag.
We distinguish them by their indices. */
{"blip", no_argument, 0, 'b'},
{"slip", no_argument, 0, 's'},
{0, 0, 0, 0}
};
/* getopt_long stores the option index here. */
int option_index = 0;
int c = getopt_long (argc, argv, "bs",
long_options, &option_index);
/* Detect the end of the options. */
if (c == -1)
break;
switch (c)
{
case 0:
/* If this option set a flag, do nothing else now. */
if (long_options[option_index].flag != 0)
break;
printf ("option %s", long_options[option_index].name);
if (optarg)
printf (" with arg %s", optarg);
printf ("\n");
break;
case 'b':
puts ("option -b\n");
break;
case 's':
puts ("option -s\n");
break;
case '?':
/* getopt_long already printed an error message. */
break;
default:
abort ();
}
}
if (verbose_flag)
puts ("verbose flag is set");
/* Print any remaining command line arguments (not options). */
if (optind < argc)
{
printf ("non-option ARGV-elements: ");
while (optind < argc)
printf ("%s ", argv[optind++]);
putchar ('\n');
}
return 0;
}
по теме:
Ответ 4
Взгляните на библиотеку getopt; это в значительной степени золотой стандарт для такого рода вещей.
Ответ 5
Другие ударили по одному по голове:
- стандартные аргументы
main(int argc, char **argv)
дают вам прямой доступ к командной строке (после того, как он был искалечен и обозначен оболочкой)
- существует очень стандартное средство для синтаксического анализа командной строки:
getopt()
и getopt_long()
но, как вы видели, код для их использования является немногословным и довольно идомальным. Я обычно выталкиваю его из вида с чем-то вроде:
typedef
struct options_struct {
int some_flag;
int other_flage;
char *use_file;
} opt_t;
/* Parses the command line and fills the options structure,
* returns non-zero on error */
int parse_options(opt_t *opts, int argc, char **argv);
Тогда сначала главное:
int main(int argc, char **argv){
opt_t opts;
if (parse_options(&opts,argc,argv)){
...
}
...
}
Или вы могли бы использовать одно из решений, предложенных в помощниках для разбора аргументов для C/UNIX.
Ответ 6
Вместо getopt()
вы также можете использовать argp_parse()
(альтернативный интерфейс к той же библиотеке).
Из руководство по libc:
getopt
является более стандартным ( вариант с короткой опцией - это часть стандарта POSIX), но используя argp_parse
часто проще, как для очень простой и очень сложный вариант структур, поскольку он делает больше грязная работа для вас.
Но я всегда был доволен стандартом getopt
.
N.B. GNU getopt
с getopt_long
является GNU LGPL.