我有一个包含以下数据的向量:
std::vector<std::string> v;
v[0] = "first:tom";
v[1] = "last:jones";
我希望遍历该向量并在:
处解析并将结果放入std::map
std::vector<std::string> v;
std::map<std::string, std::string> m;
std::pair<std::string, std::string> p;
for(int i = 0; i < v.size(); i++)
{
std::cout << v[i] << std::endl;
std::istringstream oss(v[i]);
std::string token;
while(getline(oss, token, ':'))
{
m.insert(std::pair<std::string, std::string>("", ""));
}
}
我坚持插入std::map
,因为我没看到解析如何为我提供了可以插入地图的两个部分。
两者都不是v [i]。
我想:
m.insert(std::pair<std::string, std::string>("first", "tom"));
m.insert(std::pair<std::string, std::string>("last", "jones"));
有人能解释我的困难吗?
答案 0 :(得分:3)
尝试
std::vector<std::string> v;
std::map<std::string, std::string> m;
for(int i = 0; i < v.size(); i++)
{
std::cout << v[i] << std::endl;
size_t sepPosition = v[i].find (':');
//error handling
std::string tokenA = v[i].substr(0, sepPosition);
std::string tokenB = v[i].substr(sepPosition + 1)
m.insert(std::pair<std::string, std::string>(std::move(tokenA), std::move(tokenB)));
}
答案 1 :(得分:2)
这样的事情:
std::vector<std::string> v;
std::map<std::string, std::string> m;
std::pair<std::string, std::string> p;
for(int i = 0; i < v.size(); i++)
{
std::cout << v[i] << std::endl;
std::istringstream oss(v[i]);
std::string key;
std::string value;
while(getline(oss, key, ':') && getline(oss, value))
{
m.insert(std::pair<std::string, std::string>(key, value));
}
}
答案 2 :(得分:1)
transform(v.begin(), v.end(), inserter(m, m.begin()), chopKeyValue);
chopKeyValue
的位置:
pair<string, string> chopKeyValue(const string& keyValue) {
string::size_type colon = keyValue.find(':');
return make_pair(keyValue.substr(0, colon), keyValue.substr(colon+1));
}
答案 3 :(得分:0)
又一个选项(C ++ 11):
std::vector<std::string> v = { "first:tom", "last:jones" };
std::map<std::string,std::string> m;
for (std::string const & s : v) {
auto i = s.find(':');
m[s.substr(0,i)] = s.substr(i + 1);
}