C ++ boost.python无法将const char *转换为str

问题描述 投票:0回答:1

我想用C ++计算一些东西并将结果返回给python。这是C ++代码的一部分:

const Mat& flow_map_x, flow_map_y;
std::vector<unchar> encoded_x, encoded_y;

flow_map_x = ...;
flow_map_y = ...;

Mat flow_img_x(flow_map_x.size(), CV_8UC1);
Mat flow_img_y(flow_map_y.size(), CV_8UC1);

encoded_x.resize(flow_img_x.total());
encoded_y.resize(flow_img_y.total());

memcpy(encoded_x.data(), flow_img_x.data, flow_img_x.total());
memcpy(encoded_y.data(), flow_img_y.data, flow_img_y.total());

bp::str tmp = bp::str((const char*) encoded_x.data())

运行python脚本时的错误是:

UnicodeDecodeError: 'utf-8' codec can't decode byte 0x80 in position 0: invalid start byte

调试后,我发现错误来自这一行:

bp::str tmp = bp::str((const char*) encoded_x.data())

我不擅长C ++。谁能告诉我如何修复错误?提前致谢!

python c++ boost-python
1个回答
0
投票

你不能因为encoded_x.data()不是UTF-8。您可能希望bytes获取原始数据的副本:

使用PyObject* PyBytes_FromStringAndSize(const char *v, Py_ssize_t len)。或者您可以使用PyByteArray_FromStringAndSize作为具有相同参数的bytearray

bp::object tmp(bp::handle<>(PyBytes_FromStringAndSize(
    // Data to make `bytes` object from
    reinterpret_cast<const char*>(encoded_x.data()),
    // Amount of data to read
    static_cast<Py_ssize_t>(encoded_x.size())
)));

在这种情况下,您可以摆脱向量并直接使用flow_img_x.dataflow_img_x.total()


或者memoryview不复制数据,但只是访问std::vectors数据

使用PyObject* PyMemoryView_FromMemory(char *mem, Py_ssize_t size, int flags)

bp::object tmp(bp::handle<>(PyMemoryView_FromMemory(
    reinterpret_cast<char*>(encoded_x.data()),
    static_cast<Py_ssize_t>(encoded_x.size()),
    PyBUF_WRITE  // Or `PyBUF_READ` i if you want a read-only view
)));

(如果向量是常量,你会const_cast<char*>(reinterpret_cast<const char*>(encoded_x.data()))并且只使用PyBUF_READ

在这种情况下,您必须确保向量保持活动状态,但它不会创建不必要的副本。

© www.soinside.com 2019 - 2024. All rights reserved.