2

在下面的代码中,我也想忽略字符“。但是在添加之后,我仍然得到“Mr_Bishop”作为我的输出。

我有以下代码:

    ifstream getfile;
    getfile.open(file,ios::in);
        char data[256];
    char *line;
    //loop till end of file                   
    while(!getfile.eof())
    {
            //get data and store to variable data
            getfile.getline(data,256,'\n');

        line = strtok(data," ”");
        while(line != NULL)
        {
            cout << line << endl;
            line = strtok(NULL," ");
        }
    }//end of while loop

我的文件内容:

hello 7 “Mr_Bishop”
hello 10 “0913823”

基本上我希望我的输出是:

hello
7
Mr_Bishop
hello
10
0913823

使用此代码,我只能得到:

hello
7
"Mr_Bishop"
hello
10
"0913823"

提前致谢!:)

我意识到我在内部循环中犯了一个错误,错过了报价。但现在我收到以下输出:

hello
7
Mr_Bishop
�
hello
10
0913823
�

有什么帮助吗?谢谢!:)

4

2 回答 2

2

看起来您使用写字板或其他东西来生成文件。您应该在 Windows 上使用 Notepad 或 Notepad++ 或在 Linux 上创建 ASCII 编码的类似工具。现在你正在使用看起来像 UTF-8 的编码。

此外,“正确的转义序列是 \”。例如

line = strtok(data," \"");

将文件修复为 ASCII 编码后,您会发现循环中遗漏了一些内容。

while(!getfile.eof())
{
        //get data and store to variable data
        getfile.getline(data,256,'\n');

    line = strtok(data," \"");
    while(line != NULL)
    {
        std::cout << line << std::endl;
        line = strtok(NULL," \""); // THIS used to be strtok(NULL," ");
    }
}//end of while loop

你在那里错过了一组报价。更正文件,这个错误会产生正确的输出。

于 2012-05-15T20:08:21.843 回答
1

仔细查看您的代码:

    line = strtok(data," ”");

注意引号如何以不同的角度倾斜(我的也是这样,我想希望你的字体显示相同的东西)。您在strtok()通话中只包含了结束双引号。但是,您的数据文件具有:

hello 7 “Mr_Bishop”

它有两种不同的报价。确保您使用了所有正确的字符,无论您的数据是否“正确”。

更新:你的数据可能是 UTF-8 编码的(这就是你在那里得到那些倾斜的双引号的方式)并且你正在使用strtok()它完全不知道 UTF-8 编码。所以它可能做错了,拆分多字节 UTF-8 字符,并在行尾留下垃圾。

于 2012-05-15T19:49:29.533 回答