我怎样才能得到:
connect
100
username
example
来自这个字符串:
ngg://connect>100/username>example/
答案 0 :(得分:4)
将std::string::find
与参数"/"
和">"
以及std::string::substr
与找到的索引一起使用。
这是一个好的开始。
答案 1 :(得分:3)
ngg://connect>100/username>example/
如果修复了此格式,则可以将std::sscanf
用作:
#include <iostream>
#include <cstdio>
int main()
{
char const *input = "ngg://connect>100/username>example/";
char const *input_format = "ngg://%[^>]>%d/%[^>]>%[^/]";
char connect[100], user[100], str[100]; //assuming max size is 100
int num;
if ( std::sscanf(input, input_format, connect, &num, user, str) != 4 )
{
std::cerr<<"error - number of tokens read must be equal to 4";
return 0;
}
std::cout << connect <<std::endl;
std::cout << num <<std::endl;
std::cout << user <<std::endl;
std::cout << str <<std::endl;
}
输出(online demo):
connect
100
username
example
答案 2 :(得分:3)
可能性为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("ngg://connect>100/username>example/");
boost::split(tokens, s, boost::is_any_of("/>"));
// "connect" == tokens[2]
// "100" == tokens[3]
// "username" == tokens[4]
// "example" == tokens[5]
return 0;
}
答案 3 :(得分:3)
为了多样性而添加strtok
的答案:
char str[] = "ngg://connect>100/username>example/";
char *s = strtok(str, ">/");
std::vector<std::string> tokens;
while (s = strtok(NULL, ">/"))
tokens.push_back(std::string(s));
这会将字符串str
拆分为所需的标记(丢弃第一个ngg:
,就像在问题中一样)。
这是此代码的working example。