繁体   English   中英

从文本文件C ++中读取单词(奇怪的字符)

[英]Reading words from a text file C++ (weird characters)

firstword secondword thirdword fourthword ...

我的文本文件按此顺序包含200个单词,我想读取它们并将其复制到2D固定长度的数组中,而没有奇怪的字符。 我无法使用以下代码执行此操作:

ifstream FRUITS;
FRUITS.open("FRUITS.TXT");


    if(FRUITS.is_open())
    {
        char fruits1[200][LEN];
        int c;

        for(c = 0; c < 200; c++)
        {
            char* word;
            word = new char[LEN];

            FRUITS >> word;

            for(int i = 0; i < LEN; i++)
            {
                fruits1[c][i] = word[i];
            }
        }
    }

我怎样才能做到这一点?

您需要在单词的末尾添加'\\0' ,这样,如果单词的长度小于LEN ,就不会出现任何奇怪的字符。

但是,我建议为工作使用字符串向量。

#include <iostream>
#include <fstream>
#include <vector>
#include <string>

using namespace std;
int main()
{
    fstream file;
    vector<string> v;
    file.open("FRUITS.txt");
    string tmp;
    while(!file.eof())
    {
        file >> tmp;
        v.push_back(tmp);
    }
    for(vector<string>::iterator i=v.begin(); i!=v.end(); i++)
    {
        cout << *i << endl;
    }
    file.close();
    return 0;
}

考虑一下:

FRUITS >> fruits1[c];

但是您必须确保LEN足以容纳每个单词中的所有char以及'\\0'

并且不用担心"=+½$#". 当你做类似cout << fruits1[c];事情时cout << fruits1[c]; 他们没有被打印。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM