将 Python 数据读入 C++ 代码
Read Python data into C++ code
我正在更新一个 python 代码和一个 c++ 代码,以便第二个可以读取第一个传送的数据,将其用于 运行,然后再将更新后的数据重新发送到原始 python代码。
更确切地说:
- 我的 python 文件生成了一个列表数据 [2][5]:
data = [[Cij[0, 0],Cij[0,1],Cij[0,2],Cij[2,2],Cij[3,3]],[50,50,100,100,0]]
Cij 是浮动的,我想将它保存在一个 bin 文件中,用 C++ 打开它并访问该数据以修改它。
然后,我将修改后的数据保存到另一个 bin 文件中,以便在我的 python 代码中读取它。
我想使用尽可能少的外部库来做到这一点,因为代码的目的是使它 public 如此易于使用。有任何想法吗 ?
我一直 运行 遇到数据错误,我的 C++ 代码从 bin 文件中读取的数字似乎完全错误。但是,第二部分(python 从 c++ 生成的 bin 中读取修改后的数据)似乎有效。
我目前正在做的是使用 pickle 将数据转储到 bin 中,然后我在 c++ 上访问它:
DataFile.open('Binpath', ios::binary|ios::in);
float data[2][5];
DataFile.read((char*)&data,sizeof(data));
但是当我在C++文件中打印数据时,完全错误。
所以这是一个完整的例子:
在 python 中,我正在写:
import pickle
data = [[1.1, 1.1, 1.1, 1.1], [2.2, 2.2, 2.2, 2.2]]
outfile = open("test.bin", 'wb')
pickle.dump(data, outfile)
outfile.close()
在 C++ 中:
#include <iostream>
#include <fstream>
#include <cstring>
using namespace std;
int main() {
ifstream DataFile;
DataFile.open("test.bin", ios::binary|ios::in);
if(!DataFile.is_open()){
cout<< "error"<<endl;
}
float data[2][4] = {{0.0,0.0,0.0,0.0},{0.0,0.0,0.0,0.0}};
DataFile.read((char*)&data,sizeof(data));
for (int i = 0; i<4; i++){
cout << data[0][i]<< endl;}
for (int i = 0; i<4; i++){
cout << data[1][i]<< endl;}
cin.ignore();
DataFile.close();
return 0;
}
打印结果有误。
感谢您的帮助。
所以考虑 Python 数据数组
data = [[0.1, 0.2, 0.3, 0.4, 0.5], [50, 50, 100, 100, 0]]
要在 C++ 中导入的二维数组。问题已经是数据类型:
type(data[0][0])
Out[6]: float
type(data[1][0])
Out[7]: int
如果要将其导入浮点数组,则需要将所有内容都转换为浮点。您可以为此使用 array
包。但是,我们必须按照 C++ 存储多维数组的方式来展平数组:
from array import array
dataArray = array('f', [item for sublist in data for item in sublist])
outputFile = open('outData', 'wb')
dataArray.tofile(outputFile)
outputFile.close()
在 C++ 中,我们现在可以使用文件流从文件中读取浮点数
#include <fstream>
#include <iostream>
int main()
{
float data[2][5];
std::ifstream dataFile;
dataFile.open("outData", std::ios::binary | std::ios::in);
dataFile.read((char*)&data, sizeof(data));
dataFile.close();
for (int i = 0; i < 2; i++)
for (int j = 0; j < 5; j++)
std::cout << "(" << i << ", " << j << ") = " << data[i][j] << "\n";
return 0;
}
输出
(0, 0) = 0.1
(0, 1) = 0.2
(0, 2) = 0.3
(0, 3) = 0.4
(0, 4) = 0.5
(1, 0) = 50
(1, 1) = 50
(1, 2) = 100
(1, 3) = 100
(1, 4) = 0
这只是概念验证。这当然可以做得更好...
我正在更新一个 python 代码和一个 c++ 代码,以便第二个可以读取第一个传送的数据,将其用于 运行,然后再将更新后的数据重新发送到原始 python代码。 更确切地说: - 我的 python 文件生成了一个列表数据 [2][5]:
data = [[Cij[0, 0],Cij[0,1],Cij[0,2],Cij[2,2],Cij[3,3]],[50,50,100,100,0]]
Cij 是浮动的,我想将它保存在一个 bin 文件中,用 C++ 打开它并访问该数据以修改它。 然后,我将修改后的数据保存到另一个 bin 文件中,以便在我的 python 代码中读取它。 我想使用尽可能少的外部库来做到这一点,因为代码的目的是使它 public 如此易于使用。有任何想法吗 ?
我一直 运行 遇到数据错误,我的 C++ 代码从 bin 文件中读取的数字似乎完全错误。但是,第二部分(python 从 c++ 生成的 bin 中读取修改后的数据)似乎有效。
我目前正在做的是使用 pickle 将数据转储到 bin 中,然后我在 c++ 上访问它:
DataFile.open('Binpath', ios::binary|ios::in);
float data[2][5];
DataFile.read((char*)&data,sizeof(data));
但是当我在C++文件中打印数据时,完全错误。
所以这是一个完整的例子: 在 python 中,我正在写:
import pickle
data = [[1.1, 1.1, 1.1, 1.1], [2.2, 2.2, 2.2, 2.2]]
outfile = open("test.bin", 'wb')
pickle.dump(data, outfile)
outfile.close()
在 C++ 中:
#include <iostream>
#include <fstream>
#include <cstring>
using namespace std;
int main() {
ifstream DataFile;
DataFile.open("test.bin", ios::binary|ios::in);
if(!DataFile.is_open()){
cout<< "error"<<endl;
}
float data[2][4] = {{0.0,0.0,0.0,0.0},{0.0,0.0,0.0,0.0}};
DataFile.read((char*)&data,sizeof(data));
for (int i = 0; i<4; i++){
cout << data[0][i]<< endl;}
for (int i = 0; i<4; i++){
cout << data[1][i]<< endl;}
cin.ignore();
DataFile.close();
return 0;
}
打印结果有误。
感谢您的帮助。
所以考虑 Python 数据数组
data = [[0.1, 0.2, 0.3, 0.4, 0.5], [50, 50, 100, 100, 0]]
要在 C++ 中导入的二维数组。问题已经是数据类型:
type(data[0][0])
Out[6]: float
type(data[1][0])
Out[7]: int
如果要将其导入浮点数组,则需要将所有内容都转换为浮点。您可以为此使用 array
包。但是,我们必须按照 C++ 存储多维数组的方式来展平数组:
from array import array
dataArray = array('f', [item for sublist in data for item in sublist])
outputFile = open('outData', 'wb')
dataArray.tofile(outputFile)
outputFile.close()
在 C++ 中,我们现在可以使用文件流从文件中读取浮点数
#include <fstream>
#include <iostream>
int main()
{
float data[2][5];
std::ifstream dataFile;
dataFile.open("outData", std::ios::binary | std::ios::in);
dataFile.read((char*)&data, sizeof(data));
dataFile.close();
for (int i = 0; i < 2; i++)
for (int j = 0; j < 5; j++)
std::cout << "(" << i << ", " << j << ") = " << data[i][j] << "\n";
return 0;
}
输出
(0, 0) = 0.1
(0, 1) = 0.2
(0, 2) = 0.3
(0, 3) = 0.4
(0, 4) = 0.5
(1, 0) = 50
(1, 1) = 50
(1, 2) = 100
(1, 3) = 100
(1, 4) = 0
这只是概念验证。这当然可以做得更好...