有没有什么办法来读取一个格式化字符串这样的,例如:48754+7812=Abcs
。
比方说,我有三个stringz X,Y和Z,我想
X = 48754
Y = 7812
Z = Abcs
这两个数字的大小和字符串的长度可能会有所不同,所以我不想使用substring()
或类似的东西。
是否有可能让C ++中的参数是这样
":#####..+####..=SSS.."
所以它直接知道这是怎么回事?
有没有什么办法来读取一个格式化字符串这样的,例如:48754+7812=Abcs
。
比方说,我有三个stringz X,Y和Z,我想
X = 48754
Y = 7812
Z = Abcs
这两个数字的大小和字符串的长度可能会有所不同,所以我不想使用substring()
或类似的东西。
是否有可能让C ++中的参数是这样
":#####..+####..=SSS.."
所以它直接知道这是怎么回事?
一种可能性是boost::split()
它允许多个定界符的说明书和不要求输入的大小的先验知识:
#include <iostream>
#include <vector>
#include <string>
#include <boost/algorithm/string.hpp>
#include <boost/algorithm/string/split.hpp>
int main()
{
std::vector<std::string> tokens;
std::string s(":48754+7812=Abcs");
boost::split(tokens, s, boost::is_any_of(":+="));
// "48754" == tokens[0]
// "7812" == tokens[1]
// "Abcs" == tokens[2]
return 0;
}
或者,使用sscanf()
#include <iostream>
#include <cstdio>
int main()
{
const char* s = ":48754+7812=Abcs";
int X, Y;
char Z[100];
if (3 == std::sscanf(s, ":%d+%d=%99s", &X, &Y, Z))
{
std::cout << "X=" << X << "\n";
std::cout << "Y=" << Y << "\n";
std::cout << "Z=" << Z << "\n";
}
return 0;
}
然而,这里的limitiation是该字符串(最大长度Z
)必须解析输入之前决定。
#include <iostream>
#include <sstream>
int main(int argc, char **argv) {
std::string str = ":12341+414112=absca";
std::stringstream ss(str);
int v1, v2;
char col, op, eq;
std::string var;
ss >> col >> v1 >> op >> v2 >> eq >> var;
std::cout << v1 << " " << v2 << " " << var << std::endl;
return 0;
}
您可以使用scanf
。 它不是过于C ++ - 杂交,但它确实具有显着代码几行特技:
char a[101], b[111], c[121];
sscanf(":48754+7812=Abcs", ":%100[^+]+%110[^=]=%120s", a, b, c);
string sa(a), sb(b), sc(c);
cout << sa << "-" << sb << "-" << sc << endl;
我们的想法是指定由您阅读使用非常有限的正则表达式语法字符串接受的人物。 在这种情况下,第一串被读取到加,第二个字符串被读取到等号。
例如。
#include <boost/regex.hpp>
#include <iostream>
int main()
{
boost::regex re("\":(\\d+)\\+(\\d+)=(.+)\"");
std::string example = "\":48754+7812=Abcs\"";
boost::smatch match;
if (boost::regex_match(example, match, re))
{
std::cout << "f number: " << match[1] << " s number: " << match[2] << " string: " << match[3]
<< std::endl;
}
else
{
std::cout << "not match" << std::endl;
}
}
和第二个变体,工作只与字符串。
#include <string>
#include <iostream>
int main()
{
std::string s = "\":48754+7812=Abcs\"";
std::string::size_type idx = s.find(":");
std::string::size_type end_first = s.find("+", idx + 1);
std::string f_number = s.substr(idx + 1, end_first - (idx + 1));
std::cout << f_number << std::endl;
std::string::size_type end_second = s.find("=", end_first + 1);
std::string s_number = s.substr(end_first + 1, end_second - (end_first + 1));
std::cout << s_number << std::endl;
std::string::size_type string_end = s.find("\"", end_second);
std::string str = s.substr(end_second + 1, string_end - (end_second + 1));
std::cout << str << std::endl;
}