Cでプログラミングしていても、Python自体を使ってみてください。残念ながら私はCのCTypesインターフェイスについて知らず、ソースでヒントを見つけることができませんでした。たぶんあなたはPyCTypes_Pointer
メソッドを次のように書くことができます。
ここでは、クリーンアップ、エラーチェック、または処理は行っていませんが、Python 2.7および3.4で動作しています。ちょうどあなたが唯一のゼロ終端文字列を処理している場合、あなたは多分、直接ctypes.c_char_p
を使用することができるかもしれません
from __future__ import print_function
from distutils.core import Extension, setup
import sys
sys.argv.extend(["build_ext", "-i"])
setup(ext_modules = [Extension('pyp', ['pyp.c'])])
import pyp
c = pyp.char_p()
print(c[:pyp.len()])
を構築し、
<class 'ctypes.LP_c_char'> Testing Python ctypes char pointer ...
のような出力を得る
#include <Python.h>
static const char *test = "Testing Python ctypes char pointer ...";
static PyObject *c_char_p = NULL;
static PyObject *c_void_p = NULL;
static PyObject *cast = NULL;
static PyObject * char_p (void) {
PyObject *p = PyLong_FromVoidPtr((void *) test);
p = PyObject_CallFunction(c_void_p, "O", p);
return PyObject_CallFunction(cast, "OO", p, c_char_p);
}
static PyObject *len (void) {
return PyLong_FromSize_t(strlen(test));
}
static PyMethodDef methods[] = {
{"char_p", (PyCFunction) char_p, METH_NOARGS, ""},
{"len", (PyCFunction) len, METH_NOARGS, ""},
{ NULL }
};
#if PY_MAJOR_VERSION >= 3
static PyModuleDef module = {PyModuleDef_HEAD_INIT, "pyt", "", -1, methods,
NULL, NULL, NULL, NULL};
#define INIT_FUNC PyInit_pyp
#else
#define INIT_FUNC initpyp
#endif
PyMODINIT_FUNC INIT_FUNC (void) {
PyObject* m;
PyObject *ctypes = PyImport_ImportModule("ctypes");
PyObject *c_char = PyObject_GetAttrString(ctypes, "c_char");
c_char_p = PyObject_CallMethod(ctypes, "POINTER", "O", c_char);
c_void_p = PyObject_GetAttrString(ctypes, "c_void_p");
cast = PyObject_GetAttrString(ctypes, "cast");
#if PY_MAJOR_VERSION >= 3
m = PyModule_Create(&module);
#else
m = Py_InitModule("pyp", methods);
#endif
return (PyMODINIT_FUNC) m;
}
...
何か不足していますか?あなたは質問していません:http://docs.python.org/library/ctypes.html#ctypes-pointers – mjhm
これはPythonコードです。私はCからポインタを構築する必要があります。 –
あなたはSWIGを使いたいですか?それはとても強力です~~~ – kaitian521