Owe*_*wen 6 python swig ctypes
这是Python的问题.我有一个变量A.
>>> A
<Swig Object of type 'uint16_t *' at 0x8c66fa0>
>>> help(A)
class PySwigObject(object)
Swig object carries a C/C++ instance pointer
Run Code Online (Sandbox Code Playgroud)
A引用的实例是一个连续的数组uint16 [3],问题是从Python获得对该数组的访问.
在Python中,我如何创建一个长度为3的变量B,它允许我对包含在A中的指针所指向的相同内存进行读/写访问?
我认为这个问题有两个部分:
- 如何将指针从A中取出(我认为0x8c66fa0指向Swig对象,而不是包装对象).
- 如何使用内存指针和已知数据类型初始化某种Python数组.(Numpy有一个frombuffer方法,但似乎需要的是一个记忆方法.)也许需要一些演员.
我认为这应该很容易,但我已经阅读和黑客超过一天了!
为了解决第二部分,我想一个例子可以这样开始:
>>> import numpy
>>> C = numpy.ascontiguousarray([5,6,7],"uint16")
>>> C
array([5, 6, 7], dtype=uint16)
>>> C.data
<read-write buffer for 0x8cd9340, size 6, offset 0 at 0x8902f00>
Run Code Online (Sandbox Code Playgroud)
然后尝试使用"0x8902f00"和"uint16"构建B(任何矢量类型)并测试是否更改B [2]会导致C [2]中的更改.
非常感谢您的建议或明确的例子.
问候,
欧文
经过更多的阅读和尝试后,答案如下:
1. The wrapped pointer in PySwigObject A is available as A.__long__() . 2. A raw pointer can be cast into an indexable type using ctypes as follows import ctypes pA = ctypes.cast( A.__long__(), ctypes.POINTER( ctypes.c_uint16 ) )
然后元素可以作为pA [0],pA [1]等来寻址
pA指向与原始对象相同的内存,因此在删除原始对象后请注意不要使用pA.
以下是问题第二部分的示例(在Python中使用已知类型的原始指针),
C = numpy.ascontiguousarray([5,6,7],"uint16") # make an array
C
rawPointer = C.ctypes.data
pC = ctypes.cast( rawPointer, ctypes.POINTER( ctypes.c_uint16 ))
pC[0:3]
pC[1]=100
pC[0:3]
C
Run Code Online (Sandbox Code Playgroud)
在Python中运行示例将显示C [1]和pC [1]都已更改为100.
解决了.:)
| 归档时间: |
|
| 查看次数: |
3034 次 |
| 最近记录: |