代码为
sscanf(szbuf, "%s %c %s", szTmp1, &szChar, szTmp2);
其中szubuff是fetch_query = SELECT NAME FROM TABLE1
szChar是=
szbuf
、szTmp1
、szTmp2
是字符数组。问题是szTmp2只存储SELECT
而忽略其余部分。但我需要szTmp2
中的完整SELECT NAME FROM TABLE1
#include <stdio.h>
#include <string.h>
int main(int argc, const char **argv) {
char str[] = "fetch_query = SELECT NAME FROM TABLE1";
char *qry, *sql;
qry = strtok(str, "=");
sql = strtok(0, "=");
printf("%s -- %sn", qry, sql);
return 0;
}
输出:
fetch_query -- SELECT NAME FROM TABLE1
使用这个。它将所有字符匹配到行尾:
sscanf(szbuf, "%s %c %[^n]", szTmp1, &szChar, szTmp2);
由于您使用的是C++,您应该考虑使用类型为std::string
的对象,而不是C风格的字符串,并且可以使用以下方式使用字符串流来解析格式为" var = value "
的字符串:
std::istringstream is("fetch_query = SELECT NAME FROM TABLE1");
std::string var, divider, value;
if ((is >> var >> divider) && divider == "=") // check 1
{
std::getline(is, value);
if (!value.empty()) // check 2
std::cout << "var name: " << var << std::endl
<< "value :" << value << std::endl;
}
";检查1";条件确保从流中提取2个单词,并且第二个单词等于字符串"="
。";检查2";确保在CCD_ 12之后至少还有一个字。
var name: fetch_query
value : SELECT NAME FROM TABLE1
PS:上面的例子需要#include <iostream>
和#include <sstream>
。
sscanf中的%s一次只读取一个单词,即它停止在第一个空白处。相反,您可以使用以下内容:
sscanf(szbuf, "%s %c %[0-9a-zA-Z ]", szTmp1, &szChar, szTmp2);
其中%[0-9a-zA-Z]表示只要在规范中找到输入中的字符,就保持读取(a-Z是字符范围)。