C++ 有效地从输入文件分配值
我得到一个输入文件,其中包含以下格式的一系列数据块C++ 有效地从输入文件分配值,c++,input,char,C++,Input,Char,我得到一个输入文件,其中包含以下格式的一系列数据块 CO2 Gurvich,1991 pt1 p27 pt2 p24. 3 g 9/99 C 1.00O 2.00 0.00 0.00 0.00 0 44.00950 -393510.000 200.000 1000.000 7 -2.0 -1.0 0.0 1.0 2.0
CO2 Gurvich,1991 pt1 p27 pt2 p24.
3 g 9/99 C 1.00O 2.00 0.00 0.00 0.00 0 44.00950 -393510.000
200.000 1000.000 7 -2.0 -1.0 0.0 1.0 2.0 3.0 4.0 0.0 9365.469
4.943650540E+04-6.264116010E+02 5.301725240E+00 2.503813816E-03-2.127308728E-07
-7.689988780E-10 2.849677801E-13 0.000000000E+00-4.528198460E+04-7.048279440E+00
1000.000 6000.000 7 -2.0 -1.0 0.0 1.0 2.0 3.0 4.0 0.0 9365.469
1.176962419E+05-1.788791477E+03 8.291523190E+00-9.223156780E-05 4.863676880E-09
-1.891053312E-12 6.330036590E-16 0.000000000E+00-3.908350590E+04-2.652669281E+01
6000.000 20000.000 7 -2.0 -1.0 0.0 1.0 2.0 3.0 4.0 0.0 9365.469
-1.544423287E+09 1.016847056E+06-2.561405230E+02 3.369401080E-02-2.181184337E-06
6.991420840E-11-8.842351500E-16 0.000000000E+00-8.043214510E+06 2.254177493E+03
它们代表化学反应的某些值。(在本例中为二氧化碳)。
我需要根据字符位置提取某些值,每行有80个字符。它们有不同的含义
再解释一下,
在第一行中,前16个字符给出了物种名称或公式(CO2)
然后,从字符19到80是注释。
在第二行中,字符1-2给出某些值,字符4-9给出其他值,依此类推
对于第3行,字符1-22给出了温度范围,我需要将这些值划分为不同的变量。所以
200.000 1000.000
需要变为“双V1=200.000”和“双V2=1000.000”,则字符23始终为7,但有时字符1-22和23上的值之间没有空格。
等等
好。。。我的主要问题是,什么是解决这个问题的好方法?
我在考虑将每一行划分为不同的char变量,并将输入文件中的值分配给它们。但我不确定这是否是一个好办法
此外,对于每个信息块,第3、4和5行的格式重复不同
我希望问题是清楚的,我没有写一个糟糕的问题。
我真的不需要密码答案,只要给我指出正确的方向就行了。
谢谢 如果数据的宽度是固定的,那么在正确的位置拆分就非常容易了。大致如下:
std::string input;
int lineno = 0;
std::string compound;
std::vector<double> data;
while(std::getline(cin, input))
{
if (input[0] != ' ') // Detect new "first line"
{
lineno = 0;
}
else
{
lineno ++;
}
switch(lineno)
{
case 0:
{
if (data.size() != 0)
{
// Save "data" from previous "chunk".
}
data.clear();
int i;
for(i = 0; i < input.size() && input[i] != ' '; i++);
compound = input.substr(0, i);
// May want to keep comment too: comment = input.substr(i);
// You would have to strip extra spaces.
}
break;
case 1:
case 2:
{
// Not sure what you want to do here, as I don't
// know how the data is grouped. But should roughly follow
// the "default" variety.
}
break;
default:
{
const int fieldsize = 16;
for(int i = 6; i < input.size(); i += fieldsize)
{
data.push_back(std::stod(input.substr(i, fieldsize)));
}
}
break;
}
}
std::字符串输入;
int lineno=0;
std::字符串复合词;
std::矢量数据;
while(std::getline(cin,输入))
{
if(输入[0]!='')//检测新的“第一行”
{
lineno=0;
}
其他的
{
lineno++;
}
开关(线路号)
{
案例0:
{
如果(data.size()!=0)
{
//保存上一个“块”中的“数据”。
}
data.clear();
int i;
对于(i=0;i
格式是否在列中特别指定?或者有时不同化合物的色谱柱更宽/更窄?@Matstpeterson是的,它特别适用于色谱柱。我称之为characters,因为每一列都是一个字符。它总是有80列宽。