- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我对不同版本的 python 的这种行为感到困惑,不明白为什么?
Python 2.7.5 (default, Aug 25 2013, 00:04:04)
[GCC 4.2.1 Compatible Apple LLVM 5.0 (clang-500.0.68)] on darwin
Type "help", "copyright", "credits" or "license" for more information.
>>> c="hello"
>>> a=ctypes.c_char_p(c)
>>> print(a.value)
hello
Python 3.3.5 (default, Mar 11 2014, 15:08:59)
[GCC 4.2.1 Compatible Apple LLVM 5.0 (clang-500.2.79)] on darwin
Type "help", "copyright", "credits" or "license" for more information.
>>> c="hello"
>>> a=ctypes.c_char_p(c)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: bytes or integer address expected instead of str instance
一个工作,而另一个给我一个错误。哪一个是正确的?
如果它们都是正确的,我怎样才能在 3.3.5 中实现与 2.7 相同的行为?我想将 char 指针从 python 传递给 C。
最佳答案
c_char_p
是 _SimpleCData
的子类,_type_ == 'z'
。 __init__
方法调用类型的 setfunc
,对于简单类型 'z'
是 z_set
。
在 Python 2 中,z_set
function (2.7.7) 被编写为处理 str
和 unicode
字符串。在 Python 3 之前,str
是一个 8 位字符串。 CPython 2.x str
内部使用了一个 C 空终止字符串(即以 \0
终止的字节数组),为此 z_set
可以调用PyString_AS_STRING
(即获取指向 str
对象的内部缓冲区的指针)。一个unicode
字符串首先需要被编码成字节串。 z_set
自动处理此编码并在 _objects
属性中保留对编码字符串的引用。
>>> c = u'spam'
>>> a = c_char_p(c)
>>> a._objects
'spam'
>>> type(a._objects)
<type 'str'>
在 Windows 上,默认的 ctypes 字符串编码是 'mbcs'
,错误处理设置为 'ignore'
。在所有其他平台上,默认编码是 'ascii'
,带有 'strict'
错误处理。要修改默认值,请调用 ctypes.set_conversion_mode
.例如,set_conversion_mode('utf-8', 'strict')
。
在 Python 3 中,z_set
function (3.4.1) 不会自动将 str
(现在是 Unicode)转换为 bytes
。 Python 3 中的范式转变为严格区分字符串和二进制数据。删除了 ctypes 默认转换,函数 set_conversion_mode
也是如此。您必须向 c_char_p
传递一个 bytes
对象(例如 b'spam'
或 'spam'.encode('utf-8' )
)。在 CPython 3.x 中,z_set
调用 C-API 函数 PyBytes_AsString
获取指向 bytes
对象的内部缓冲区的指针。
请注意,如果 C 函数修改了字符串,那么您需要改为使用 create_string_buffer
创建一个 c_char
数组。查找类型为 const
的参数,以了解使用 c_char_p
是安全的。
关于python - ctypes c_char_p 的不同行为?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23852311/
我正在开发一个用于密码学的 Python 库。我想通过使用 GMP 在 C++ 中编写主要类来优化我的库。我编写了 C++ 类并编写了 extern 方法来使用主要的算术运算:加法、减法等...这些方
考虑以下 C 函数: void AssignPointer(char **p) { *p = "Test1"; } char* Return() { return "Test2"; }
我正在启动 3 个进程,我希望它们将一个字符串放入一个共享数组中,在与进程 (i) 对应的索引处。 看下面的代码,生成的输出是: ['test 0', None, None] ['test 1', '
我想将一个字符指针数组传递给一个 C 函数。 我指的是 http://docs.python.org/library/ctypes.html#arrays 我写了下面的代码。 from ctypes
我对不同版本的 python 的这种行为感到困惑,不明白为什么? Python 2.7.5 (default, Aug 25 2013, 00:04:04) [GCC 4.2.1 Compatible
我有一个指向结构的指针。在该结构中,其中一个字段是 POINTER(c_char)。我正在尝试设置基础值,以便更改会反射(reflect)在任何其他具有指向同一地址的指针的应用程序中。 class f
我定义了一个名为 TestStruct 的简单 C 结构和一个函数 init_struct 来创建实例并返回指向它的指针 #include #include typedef struct {
我写了一个简单的 C++ 程序来说明我的问题: extern "C"{ int test(int, char*); } int test(int i, char* var){ if (
我想提取 ctypes.c_char_p 实例指向的整数地址。 例如,在 >>> import ctypes >>> s = ctypes.c_char_p("hello") >>> s c_char
我需要通过将其转换为数组来访问 char* 的内容 这是一个演示: from ctypes import * foo = (c_char * 4)() foo.value = "foo" print
在 Python 中,我有一个 ctypes.c_char_p 的字符串,'Hello, world'。似乎 python 自动将它编码为一个数字(从我的 ipython 控制台看下面)。如何从 ct
我正在为它编写一个 C DLL 和一个 python 脚本,如下所示: //test.c __declspec(dllexport) HRESULT datafromfile(char * filen
from ctypes import * 和 In [27]: sizeof(c_char_p) Out[27]: 8 In [28]: sizeof(c_uint64) Out[28]: 8 In
我对 python3 中的 ctypes 有疑问。 我正在尝试获取一个 c_char_p 作为 python 字节对象。 以下代码试图将其值作为 python3 字节对象获取。 如何获取字节对象的值?
在 Python 3 中 function_name.restype = c_char_p # returns bytes 我有很多这样的函数,我需要为每个函数执行 str(ret, 'utf8')。
我是一名优秀的程序员,十分优秀!