我正在获取带有以下格式的一系列数据块的输入文件。

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

需要变为“double V1 = 200.000”和“double 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;
    }
 }

关于c++ - 有效分配输入文件中的值,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/23559651/

10-11 18:57