我的程序是读取包含一些销售记录的文件,并将时间,日期,价格,数量和其余内容分开。然后分别将它们中的每一个存储在矢量中。所有记录都是:
10/10/2013 04:57:27 PM,5.81,5000,29050.00,LT XT
10/10/2013 04:48:05 PM,5.81,62728,364449.68,SX XT
10/10/2013 04:10:33 PM,.00,0,.00,
10/10/2013 04:10:33 PM,.00,0,.00,
10/10/2013 04:10:33 PM,.00,0,.00,
5行。
然后我的代码是:
void main()
{
vector<string> date, time, price, volume, value, condition;
int len;
load(date,time,price,volume,value,condition);
len = date.size();
for (int i=0 ; i<len ; i++)
{
cout << date[i] << endl;
}
cout << "****************************" << endl;
for (int i=0 ; i<time.size() ; i++)
{
cout << time[i] << endl;
}
}
功能加载的定义是:
void load(vector<string> &object1,
vector<string> &object2,
vector<string> &object3,
vector<string> &object4,
vector<string> &object5,
vector<string> &object6)
{
string str1,str2,str3,str4,str5,str6;
string filename;
cout << "Enter name of file to read (one word only): ";
cin >> filename;
ifstream fptr(filename);
if (fptr.rdstate() == 0) // no error open file
{
while (!fptr.eof())
{
getline(fptr,str1,' ');
object1.push_back(str1);
getline(fptr,str2,',');
object2.push_back(str2);
getline(fptr,str3,',');
object3.push_back(str3);
getline(fptr,str4,',');
object4.push_back(str4);
getline(fptr,str5,',');
object5.push_back(str5);
getline(fptr,str6,',');
object6.push_back(str6);
}
}
else
{
cerr << "Could not open file \"" << filename << "\" for reading." << endl;
}
cout << "- after load function" << endl;
}
然后我得到下面的有线结果。我不知道我哪里错了。
矢量日期的结果(4个结果应为5并混淆所有内容):
二〇一三年十月十日
5.81,62728,364449.68,SX
.00,0,0.00
二〇一三年十月十日
向量时间的结果(同样的问题):
04:57:27 PM
XT
10/10/2013 04:10:33 PM
04:10:33 PM
答案 0 :(得分:0)
你永远不会以getline
作为终结者来做'\n'
,所以这个
将被读作完全像任何其他角色,作为一部分
“线”。
我个人的偏好是循环阅读完整版
一次一行,然后使用std::regex
(或boost::regex
)
把它分成几个字段。这确保了如果有的话
在一行中出错,您立即重新同步
正确地在下一行。
换句话说,当您第一次打电话给load
时
条件(最后一个字段),您阅读"LT XT\n10/10/2013 04:48:05 PM"
。当你试图获得时,下一次调用load
日期,您将阅读"5.81,62728,364449.68,SX"
,即
说,直到下一个空白。