[英]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.