檔案(File)物件¶
这些 API 是对内置文件对象的 Python 2 C API 的最小化模拟,它过去依赖于 C 标准库的带缓冲 I/O (FILE*
) 支持。 在 Python 3 中,文件和流使用新的 io
模块,该萨凡纳的操作系统的低层级无缓冲 I/O 之上定义了几个层。 下面介绍的函数是针对这些新 API 的便捷 C 包装器,主要用于解释器的内部错误报告;建议第三方代码改为访问 io
API。
-
PyObject *
PyFile_FromFd
(int fd, const char *name, const char *mode, int buffering, const char *encoding, const char *errors, const char *newline, int closefd)¶ - 返回值:新的引用。 Part of the Stable ABI.
根据已打开文件 fd 的文件描述符创建一个 Python 文件对象。 参数 name, encoding, errors 和 newline 可以为
NULL
表示使用默认值;buffering 可以为 -1 表示使用默认值。 name 会被忽略仅保留用于向下兼容。 失败时返回NULL
。 有关参数的更全面描述,请参阅io.open()
函数的文档。警告
由于Python流具有自己的缓冲层,因此将它们与 OS 级文件描述符混合会产生各种问题(例如数据的意外排序)。
3.2 版更變: 忽略 name 屬性。
-
int
PyObject_AsFileDescriptor
(PyObject *p)¶ - Part of the Stable ABI.
将与 p 关联的文件描述符作为
int
返回。 如果对象是整数,则返回其值。 如果不是,则如果对象存在fileno()
方法则调用该方法;该方法必须返回一个整数,它将作为文件描述符的值返回。 失败时将设置异常并返回-1
。
-
PyObject *
PyFile_GetLine
(PyObject *p, int n)¶ - 返回值:新的引用。 Part of the Stable ABI.
等价于
p.readline([n])
,这个函数从对象 p 中读取一行。 p 可以是文件对象或具有readline()
方法的任何对象。 如果 n 是0
,则无论该行的长度如何,都会读取一行。 如果 n 大于0
,则从文件中读取不超过 n 个字节;可以返回行的一部分。 在这两种情况下,如果立即到达文件末尾,则返回空字符串。 但是,如果 n 小于0
,则无论长度如何都会读取一行,但是如果立即到达文件末尾,则引发EOFError
。
-
int
PyFile_SetOpenCodeHook
(Py_OpenCodeHookFunction handler)¶ 重写
io.open_code()
的正常行为,将其形参通过所提供的处理程序来传递。处理器是一个类型为
PyObject *(*)(PyObject *path, void *userData)
的函数,其中 path 会确保为PyUnicodeObject
。userData 指针会被传入钩子函数。 因于钩子函数可能由不同的运行时调用,该指针不应直接指向 Python 状态。
鉴于这个钩子专门在导入期间使用的,请避免在新模块执行期间进行导入操作,除非已知它们为冻结状态或者是在
sys.modules
中可用。一旦钩子被设定,它就不能被移除或替换,之后对
PyFile_SetOpenCodeHook()
的调用也将失败,如果解释器已经被初始化,函数将返回 -1 并设置一个异常。此函数可以安全地在
Py_Initialize()
之前调用。引发一个不带参数的 审计事件
setopencodehook
。3.8 版新加入.
-
int
PyFile_WriteObject
(PyObject *obj, PyObject *p, int flags)¶ - Part of the Stable ABI.
将对象 obj 写入文件对象 p 。 flags 唯一支持的标志是
Py_PRINT_RAW
;如果给定,则写入对象的str()
而不是repr()
。成功时返回0
,失败时返回-1
。 将设置适当的例外。
-
int
PyFile_WriteString
(const char *s, PyObject *p)¶ - Part of the Stable ABI.
寫入字串 s 到 檔案物件 p。當成功時回傳 0,而當失敗時回傳 -1,並會設定合適的例外狀況。