有效地从输入文件中分配值

时间:2014-05-09 08:12:01

标签: 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  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) 然后,从char 19到80是笔记。 在第二行中,字符1-2给出某些值,字符4-9其他值,依此类推......

对于第3行,字符1-22给出温度范围,我需要将值分成不同的变量。所以,

         200.000  1000.000 

需要变为“double V1 = 200.000”和“double V2 = 1000.000”,然后字符23始终为7,但有时字符1-22和23之间的值之间没有空格。 等等... 嗯......我的主要问题是,有什么方法可以解决这个问题? 我正在考虑将每一行划分为不同的char变量,并将输入文件中的值分配给它们。但我不确定这是否是一个好方法。

此外,第3,4和5行的格式对每个信息块重复不同。

我希望问题很明确,我不是在写一个糟糕的问题。 我真的不需要代码答案,只是指向正确的方向。 谢谢!

1 个答案:

答案 0 :(得分:1)

如果数据是固定的宽度,那么在正确的地方拆分真的很容易。这些方面的东西:

  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;
    }
 }