错误写入Excel文件-C++
Bug writing into Excel file - C++
当我将变量发送到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;
}
我所做的就是填充一个向量和一个数组。如果我打印变量的值,我就会得到期望的值。如果我把它发送到.txt中,我会得到期望的值。如果我只将值发送到Excel中,我就会得到期望的值。
当我将容器中的值发送到Excel时,一切都会崩溃。为什么会发生这种情况?
这里可能存在的问题是Excel
解释c++
程序的(格式化的(数字输出的方式。即使文本可能是正确的(从cout
函数的角度来看(,其中也可能没有"正确"的小数点字符(即用点代替逗号,或者反之亦然(。
解决方案:确保Excel
设置为使用与默认c++
语言环境相同的"语言环境",或者将c++
语言环境设置为Excel
使用的任何语言环境。
MS-XLS文件格式不是一个简单的文本文件。您不能简单地将文本放入其中并期望它正确显示。你需要更多的代码和/或专门的库来与之交互
请参阅此处的建议。
相关文章:
- .cpp和.h文件中的模板专用化声明
- 为什么两个不同的未命名名称空间可以共存于一个cpp文件中
- 文本文件中的单词链表
- CMake-按正确顺序将项目与C运行时对象文件链接
- 使用新行和不使用新行读取文件
- 在C++程序中输入的文本文件将不起作用,除非文本被复制和粘贴
- 挂起和取消挂起一个文件DLL
- 如何确定我已使用非编码文件到达 EOF?
- 命名空间中具有.h和.cpp文件的类
- 如何使用ndk-build.cmd构建Android.so文件
- 从包含m行的文件中提取n行,必要时(惰性地)重复该文件
- 读取文件并输入到矢量中
- 在C++中查找文件
- c++库的公共头文件中应该包含什么
- 用c++从输入文件中读取另一行
- Cppcheck生成xml转储文件
- 读取文件的最后一行并输入到链接列表时出错
- 无法编译 rtmidi 测试 cmidiin.cpp 文件, 非法指令
- 如何将内容数组写入文本文件?
- C++ Windows 驱动程序MSB3030无法复制该文件,因为它找不到