将<vector> <string>转换为<vector> <int> C ++,Win32 </int> </vector> </string> </vector>

时间:2013-03-25 16:18:12

标签: c++ string vector

是否有一些方法可以将矢量转换为C ++中的矢量,win32?

我有这个带数字的字符串向量:

std::vector<std::string> DataNumbers;

我需要将此矢量字符串转换为矢量整数。

4 个答案:

答案 0 :(得分:23)

假设:

std::vector<std::string> DataNumbers;
// Fill DataNumbers
std::vector<int> Data;

您可以使用std::transform。使用std::back_inserter将值插入std::vector<int>。对于一元函数,使用使用std::stoi的lambda表达式将字符串转换为整数。

std::transform(DataNumbers.begin(), DataNumbers.end(), std::back_inserter(Data),
               [](const std::string& str) { return std::stoi(str); });

这是一个没有lambdas的版本(改为使用std::bind):

typedef int(*stoi_type)(const std::string&, std::size_t*, int);
std::transform(DataNumbers.begin(), DataNumbers.end(), std::back_inserter(Data),
               std::bind(static_cast<stoi_type>(&std::stoi),
                         std::placeholders::_1, nullptr, 10));

答案 1 :(得分:4)

C ++的做法是:

vector<std::string> input = ...;
vector<int> output;

for (auto &s : input) {
    std::stringstream parser(s);
    int x = 0;

    parser >> x;

    output.push_back(x);
}

在输入失败时不知道你想做什么,这里没有更多要说的。

答案 2 :(得分:2)

试试这个:

   std::vector<std::string> DataNumbers;
    // Fill DataNumbers
    std::vector<int> intNumbers;
    for (int i=0; i<= 5; i++)
    {
     int num = atoi(DataNumbers.at(i).c_str());
     intNumbers.push_back(num);
    }

答案 3 :(得分:1)

怎么样:

#include <algorithm>
#include <boost/lexical_cast.hpp>

template<typename C1, typename C2>
void castContainer(const C1& source, C2& destination)
{
    typedef typename C1::value_type source_type;
    typedef typename C2::value_type destination_type;
    destination.resize(source.size());
    std::transform(source.begin(), source.end(), destination.begin(), boost::lexical_cast<destination_type, source_type>);
}

它可以转换vector&lt; string&gt;到vector&lt; int&gt;,以及其他容器&lt; T1&gt;进入container2&lt; T2&gt;,例如:list - &gt;列表。

完整代码:

#include <iostream>
#include <vector>
#include <algorithm>
#include <iterator>
#include <string>
#include <boost/lexical_cast.hpp>

template<typename C1, typename C2>
void castContainer(const C1& source, C2& destination)
{
    typedef typename C1::value_type source_type;
    typedef typename C2::value_type destination_type;
    destination.resize(source.size());
    std::transform(source.begin(), source.end(), destination.begin(), boost::lexical_cast<destination_type, source_type>);
}

template<typename T, typename T2>
std::vector<T>& operator<<(std::vector<T>& v, T2 t)
{
    v.push_back(T(t));
    return v;
}

main(int argc, char *argv[])
{   
    std::vector<std::string> v1;
    v1 << "11" << "22" << "33" << "44";
    std::cout << "vector<string>: ";
    std::copy(v1.begin(), v1.end(), std::ostream_iterator<std::string>(std::cout, ", "));
    std::cout << std::endl;

    std::vector<int> v2;
    castContainer(v1, v2);

    std::cout << "vector<int>: ";
    std::copy(v2.begin(), v2.end(), std::ostream_iterator<int>(std::cout, ", "));
    std::cout << std::endl;
}