Qt从5.2版开始提供了两个类QCommandLineOption和QCommandLineParser来解析应用的命令行参数。
一、命令行写法
命令行:"-abc"
在QCommandLineParser的解析模式为ParseAsCompactedShortOptions(默认)时会被认为是3个参数,即"-a"、"-b"和"-c"
1 QCommandLineOption op1("a"); 2 QCommandLineOption op2("b"); 3 QCommandLineOption op3("c"); 4 5 QCommandLineParser parser; 6 parser.addOption(op1); 7 parser.addOption(op2); 8 parser.addOption(op3); 9 parser.process(a); 10 11 qDebug() << parser.isSet(op1); // true 12 qDebug() << parser.isSet(op2); // true 13 qDebug() << parser.isSet(op3); // true
反之,当解析模式为ParseAsLongOptions时,"-abc"会被认为是1个长命令,即"-abc"
但是由于长命令应该是以"--"开头,所以下面的代码会出现异常,提示"未知的选项"
1 QCommandLineOption op1("a"); 2 QCommandLineOption op2("b"); 3 QCommandLineOption op3("c"); 4 5 QCommandLineParser parser; 6 parser.setSingleDashWordOptionMode(QCommandLineParser::ParseAsLongOptions); 7 parser.addOption(op1); 8 parser.addOption(op2); 9 parser.addOption(op3); 10 parser.process(a); // 抛出异常,程序退出:Unknown option 'abc'.
Qt推荐使用ParseAsCompactedShortOptions模式,这也是默认的解析模式。而ParseAsLongOptions模式则是为了兼容而存在。
二、带值的命令
命令行参数通常就分为两种,带值的和不带值的。不带值的就直接注册一个命令就行了,比如上面的
QCommandLineOption op1("a");
我们可以把这个"-a"理解为一个bool类型的命令。如果需要带值,则把值写在命令后面即可,值和命令之间用等号或空格隔开,字符串可以用双引号括起来
-a ABC
-a=ABC
继续看一段代码,假设命令行为"-a="C:/A B/Demo.exe""
1 int main(int argc, char *argv[]) 2 { 3 QApplication a(argc, argv); 4 5 // -a="C:/A B/Demo.exe" 6 QCommandLineOption op1("a"); 7 QCommandLineParser parser; 8 parser.addOption(op1); 9 parser.process(a); // 异常 Unexpected value after '-a'. 10 qDebug() << parser.isSet(op1); 11 qDebug() << parser.value(op1); 12 13 MainWindow w; 14 w.show(); 15 16 return a.exec(); 17 }
由于我们定义的op1并没有说明其会有参数,而实际的命令行后面跟了个参数,解析器就会报错。Qt文档中也表示,解析器不支持可选参数。
如果需要附带参数,则必须指定一个期望值
1 int main(int argc, char *argv[]) 2 { 3 QApplication a(argc, argv); 4 5 // -a="C:/A B/Demo.exe" 6 QCommandLineOption op1("a"); 7 op1.setValueName("path"); // 期望值是路径,设置了ValueName后,解析器会认为此命令带值 8 QCommandLineParser parser; 9 parser.addOption(op1); 10 parser.process(a); 11 qDebug() << parser.value(op1);// "C:/A B/Demo.exe" 12 13 MainWindow w; 14 w.show(); 15 16 return a.exec(); 17 }
设置了ValueName后,解析器就会认为此命令带值,将会认为下一个等号或空格后的值就是参数
这个ValueName名字随便取,只是起到一个指导性的作用。你甚至可以将它设置为"abc"
另外,值可以有多个
1 int main(int argc, char *argv[]) 2 { 3 QApplication a(argc, argv); 4 5 // -a="C:/A B/Demo.exe" -a "Hello world" 6 QCommandLineOption op1("a"); 7 op1.setValueName("test"); 8 Q CommandLineParser parser; 9 parser.addOption(op1); 10 parser.process(a); 11 qDebug() << parser.values(op1);// ("C:/A B/Demo.exe", "Hello world") 12 13 MainWindow w; 14 w.show(); 15 16 return a.exec(); 17 }
还有QCommandLineParser的addHelpOption()、addVersionOption()都是添加显示命令版本和帮助用的,一般只有命令行程序才会用到吧,就不细说了。
解析可以用parse()方法或process()方法,前者遇到不可解析的命令会返回false但不会抛出异常,后者则会抛出异常。
最后,看一个比较完整的示例
1 // -a --BBB -c -D=Jack --Age -m=Hello -m "World" 2 int main(int argc, char *argv[]) 3 { 4 QApplication a(argc, argv); 5 6 QCommandLineOption op1("a");// 短名称,无参数 7 QCommandLineOption op2("BBB");// 长名称,无参数 8 QCommandLineOption op3(QStringList() << "c" << "CCC");// 多个名称,无参数 9 QCommandLineOption op4("D", "", "Name");// 短名称,有参数,无默认值 10 QCommandLineOption op5("Age", "", "", "18");// 长名称,有参数,有默认值 11 QCommandLineOption op6("m", "", "."); // 短名称,有参数,无默认值 12 13 QCommandLineParser parser; 14 parser.addOption(op1); 15 parser.addOption(op2); 16 parser.addOption(op3); 17 parser.addOption(op4); 18 parser.addOption(op5); 19 parser.addOption(op6); 20 parser.process(a); 21 22 qDebug() << parser.isSet(op1); // true 23 qDebug() << parser.isSet("BBB"); // true 24 qDebug() << parser.isSet("CCC"); // true 25 qDebug() << parser.value(op4); // "Jack" 26 qDebug() << parser.value(op5); // "18" 27 qDebug() << parser.values(op6);// ("Hello", "World") 28 29 qDebug() << parser.helpText(); 30 MainWindow w; 31 w.show(); 32 33 return a.exec(); 34 }
标签:addOption,op1,QCommandLineOption,parser,argv,QCommandLineParser,Qt From: https://www.cnblogs.com/ybqjymy/p/17582214.html