C++ 将错误写入Excel文件-C++;

C++ 将错误写入Excel文件-C++;,c++,excel,memory,fstream,C++,Excel,Memory,Fstream,当我将变量发送到Excel时,它会更改其值。这只发生在excel中。当变量存储在容器中时也会发生这种情况。我想如果你看到代码,就会更清楚: #include<iostream> #include<array> #include<vector> #include<fstream> const int aSize{ 150000 }; std::array<double, aSize> anArray{}; int main(void)

当我将变量发送到Excel时,它会更改其值。这只发生在excel中。当变量存储在容器中时也会发生这种情况。我想如果你看到代码,就会更清楚:

#include<iostream>
#include<array>
#include<vector>
#include<fstream>

const int aSize{ 150000 };
std::array<double, aSize> anArray{};

int main(void)
{
    double aValue{ 0.00000005467 };
    std::vector<double> aVector;
    for (int i = 0; i < aSize; ++i)
    {
        anArray[i] = aValue;
        aVector.push_back(aValue);
    }

    std::ofstream fileOne, fileTwo, fileThree, fileFour, fileFive;
    fileOne.open("array.xls"); 
    fileTwo.open("array.txt");
    fileThree.open("vector.xls");
    fileFour.open("vector.txt");
    fileFive.open("value.xls");

    fileOne << anArray[0];
    fileTwo << anArray[0];
    fileThree << aVector[0];
    fileFour << aVector[0];
    fileFive << aValue;

    std::cout << aValue << "\n" << anArray[0] << "\n" << aVector[0];

    return 0;
}
#包括
#包括
#包括
#包括
国际建筑工程{150000};
std::数组数组{};
内部主(空)
{
双保险{0.00000005467};
向量向量向量机;
for(int i=0;ifileOneMS-XLS文件格式不是简单的文本文件。您不能简单地将文本放入其中并期望它正确显示。您需要更多的代码和/或专用库来与之交互


请参阅。

MS-XLS文件格式不是简单的文本文件。您不能简单地将文本放入其中并期望其正确显示。您需要更多的代码和/或专用库来与之交互


请参阅。

这里可能存在的问题是
Excel
解释
c++
程序的(格式化)数字输出的方式。即使文本可能是正确的(从
cout
函数的角度来看),它也可能没有“正确”的小数点字符(即用点代替逗号,反之亦然)


解决方案:确保将
Excel
设置为使用与默认
c++
区域设置相同的“区域设置”,或者将
c++
区域设置为
Excel
正在使用的任何
c++
程序的数字输出。即使文本可能是正确的(从
cout
函数的角度来看),也可能没有“正确”的小数点字符(即点而不是逗号,反之亦然)


解决方案:确保将
Excel
设置为使用与默认
c++
区域设置相同的“区域设置”,或者将
c++
区域设置为
Excel
正在使用的任何内容。

也许我在这里不太合适,但您是否可以只使用简单(文本)命令写入
.xls
文件输出?我认为
.xls
文件比这要复杂得多。@Adrian我试过.xls、.xlsx、.csv。它们都给了我相同的结果。我刚试过你的代码,我在所有五个文件中都得到了相同的(正确的)值。你在使用什么编译器/平台?@physicsdf你不能天真地将文本写入Excel文件(.xls或.xlsx)也许解释小数点(点/逗号不匹配)有问题吗?检查Excel和/或C++环境中的“区域设置”。也许我在这里不在,但是你能用简单的(文本)来写到<代码> .xLs/COD>文件吗?输出?我认为
.xls
文件比这要复杂得多。@Adrian我试过.xls、.xlsx、.csv。它们都给了我相同的结果。我刚试过你的代码,我在所有五个文件中都得到了相同的(正确的)值。你在使用什么编译器/平台?@physicsdf你不能天真地将文本写入Excel文件(.xls或.xlsx).可能在解释小数点时存在问题(点/逗号不匹配)?请检查“区域设置”设置Excel和/或C++环境。https://github.com/jmcnamara/libxlsxwriter.git
是一个很好的编写器。但是它不允许您将数据添加到现有的excel文件中。
https://github.com/jmcnamara/libxlsxwriter.git
是一个很好的作者。但是它不允许您将数据添加到现有的excel文件中。但这里有什么困扰我的这就是为什么
cout
调用对容器对象的格式不同;我本以为所有给
的五个值都不同,但让我感到困扰的是为什么
cout
调用对容器对象的格式不同;我本以为所有给