字符串向量、列表或其他什么?C++

Vector of Strings, List or something else? C++

本文关键字:什么 C++ 其他 向量 列表 字符串      更新时间:2023-10-16

I当前有一个已自动协作到txt文件中的数据列表。目前,我正在将它加载到一个缓冲区中,根据新行对其进行分段,并将每一行添加到一个向量字符串中。目前的最终结果是:我有一个字符串向量(已确认使用cout)。

我的问题是,我将需要删除每个部分的各个部分,在某些情况下,出于格式化的原因,切割部分并移动它们,类似于数据库。

例如

1. Bernice Armstrong asd-ssdd 123123
2. Johnathan Potter asd-ssdd 123123
3. Kay Dixon asd-ssdd 123123
4. Melba Barton asd-ssdd 123123
5. Alison Malone asd-ssdd 123123
6. Mercedes Hale asd-ssdd 123123
7. Carolyn Rodriquez
asd-ssdd 123123
8. Norma Banks asd-ssdd 123123
9. Homer Burke asd-ssdd 123123
10. Mary Kelly asd-ssdd 123123

我需要剪切第8行,并将其附加到Carolyn Rodriquez的末尾。我似乎在尝试用向量类实现字符串命令时遇到了困难,因为向量类正在测试大小。

vector<string> myvect;
//...
if(strlen(myvect[2])<16)
    myvect.erase (i);

最终结果是一个CSV文件,每行都有名字和姓氏,仅此而已。我应该如何使用内置库来解决这个问题?我是在寻找合适的应用程序,还是列表或其他方法会更容易?


到目前为止我所拥有的:

int PostProcess(std::ofstream &file, char* pbuffer, size_t len)
{
    char * buffer = pbuffer;
    char tmp[160];
    vector<string> data;
    string line;
    unsigned int initial = 0;
    int count = 0;
    //dynamically assign array of memory
    for (unsigned int pos = 0; pos< len;pos++)
    {
        tmp[count] = *buffer;
        if ((*buffer) == 'n')
        {
            tmp[count+1] = 0;
            line = tmp;
            data.push_back(line);
            initial = pos;
        }
        if (count >= 150)
            break;
        buffer++;
        count = pos - initial;
    }
    //debugger - shows all data in vector
    for (std::vector<string>::const_iterator i = data.begin(); i != data.end(); ++i)
        std::cout << *i << ' ';
    //end debug code
    buffer = pbuffer;
    file << buffer;
    return 0;
}

就存储而言,我认为stijn的想法是将名称成对存储在向量中的好主意,但对您来说最容易的是!

下面是一些粗糙的快速编写和未经测试的示例代码:

char *start = pBuffer;
char *end = pBuffer;
char *max = (pBuffer + len);
vector<pair<string, string>> name_vect;
for (unsigned int pos = 0; pos < len; pos++)
{
    string name_first;
    string name second;
    // Get first name
    while (*end != ' ' && end <= max) end++;
    name_first.assign(start, end - start);
    start = ++end; // move pointers on
    // Get second name
    while (*end != ' ' && end <= max) end++;
    name_second.assign(start, end - start);
    start = ++end; // move pointers on
    // Move to the end of the line
    while (*end != 'n' && end <= max) end++;
    start = ++end; // move pointers on
    // Now we have a named pair add them to the vector
    name_vect.pushback(std::make_pair (name_first, name_second));
}

一个粗略的例子是,如何在列表中尽量不更改代码:)如果你以后想移动东西,可以使用vector.esers()和vector.insert()来删除和添加词条。

或者,如果您想将整行存储为std::string,那么您可以使用substr()函数来提取该字符串的一部分。

我会将数据读取到合适的结构中,并打印回我需要的

#include <iostream>
#include <iterator>
#include <fstream>
#include <vector>
struct Data
{
    size_t num;
    std::string name;
    std::string surname;
    std::string code;
    size_t id;
};
std::istream& operator>>(std::istream& is, Data& d)
{
    is >> d.num;
    is.ignore(2);    // skip '. '
    is >> d.name;    // take into consideration that 
    is >> d.surname; // a name or surname like 'de palma' will
    is >> d.code; //not work 
    is >> d.id;      
    return is;
}
std::ostream& operator<<(std::ostream& os, const Data& d)
{
    // Do everything you need here 
    // in term of formatting
    os << d.name << "," << d.surname;
    return os;
}
int main(int argc, char *argv[])
{
    if (argc == 1) { std::cerr << "please give me a file to process" << std::endl; return 0; }
    std::ifstream ifStream(argv[1]); // consider to have a file with data in it
    std::istream_iterator<Data> begin(ifStream);
    std::istream_iterator<Data> end;
    std::vector<Data> data (begin, end);
    std::copy(data.begin(),
              data.end(),
              std::ostream_iterator<Data>(std::cout, "n"));
    return 0;
}