0

当前代码:

void LinkedList::readFunct( string file ) {
string word;
string trailing_char;
stringstream ss;

ifstream infile ( file.c_str() );
while ( getline( infile, word)) {
    cout << "The line is " << word << endl;
    ss << word;
    while ( getline ( ss, word, ' ' )) {
        trailing_char = "space";
        cout << "Word: " << word << endl << "Trail: "<< trailing_char << endl;
    }
    ss.str( string() );
    ss.clear();
}
}

代码尝试从文本文件中提取(传递给它的名称),通读它,找到单词(由空格或换行符分隔),然后找出尾随字符(提到的空格或新队)

所以一个像这样的文本文件:

abc def ghi

jkl mno pqr

应该有 abc 后跟一个空格, ghi 和 pqr 后跟一个新行(我知道实际上它不会,但我将所有内容分配给一个链表以供以后使用,我需要知道这是结束线)。

我试图解决这个难题好几个小时了,我束手无策。帮助?

4

3 回答 3

2

std::getline(in, word)您首先使用它将吃掉所有换行符的字符串。当您再使用std::getline(in, word, ' ')最后一个词时,可能会紧跟其后没有任何内容,即,它位于行边界处。检查换行符和空格之间差异的方法是检查内部是否std::getline()由于空格或到达字符串末尾而停止,在这种情况下,它实际上停止了,因为以下字符是换行符:

while (std::getline( infile, word)) {
    std::cout << "The line is '" << word << "'\n";
    ss.clear();
    ss.str(word);
    while (std::getline (ss, word, ' ' )) {
        trailing_char = ss.eof()? "newline": "space";
        cout << "Word: " << word << endl << "Trail: "<< trailing_char << '\n';
    }
}

一种更简单的方法是一次只读取一个单词并打印单词后面的字符是否存在、空格或换行符(或其他空白字符之一):

for (std::string word; infile >> word; ) {
    switch (infile.peek()) {
    case '\n': trail = "newline"; break;
    case '\r': trail = "carriage-return"; break;
    case ' ': trail = "space"; break;
    case '\f\: trail = "form-feed"; break;
    // ...?
    default: trail = "end-of-file"; break;
    }
    std::cout << "word='" << word << "' trail=" << trail << '\n';
}
于 2013-09-20T21:37:01.850 回答
1

好吧,getline默认情况下用换行符分隔,所以这应该是你所需要的。例子:

std::ifstream infile("text.txt");

for (std::string line; std::getline(infile, line); )
{
    std::istringstream iss(line);
    bool firstword = true;
    for (std::string word; iss >> word; )
    {
        if (!firstword) { std::cout << "SPACE\n"; }
        std::cout << word;
        firstword = false;
    }
    std::cout << "NEWLINE\n";
}

布尔标志的复杂性是因为你的空间比你的单词少一个。

于 2013-09-20T21:29:36.463 回答
0

我编辑了你的代码:

void LinkedList::readFunct( string file ) {
string word;
string trailing_char;
stringstream ss;

ifstream infile ( file.c_str() );
while ( getline( infile, word)) {
    cout << "The line is " << word << endl;
    ss << word;
    bool firsttime = true;
    while ( ss >> word ) {
        if (!firsttime)
             cout << "Trail: space" << endl;
        cout << "Word: " << word << endl;
        firsttime = false;
    }
    if (!firsttime)
         cout << "Trail: NEWLINE" << endl;
    else
         cout << "empty line." << endl;
    ss.str( string() );
    ss.clear();
}
}
于 2013-09-20T21:51:47.837 回答