posix
— 最常见的 POSIX 系统调用¶
此模块提供对由 C 标准和 POSIX 标准(一个伪装得很好的 Unix 接口)标准化的操作系统功能的访问。
可用性:Unix。
不要直接导入此模块。相反,导入模块 os
,它提供了此接口的可移植版本。在 Unix 上,os
模块提供 posix
接口的超集。在非 Unix 操作系统上,posix
模块不可用,但始终可以通过 os
接口获得一个子集。一旦导入 os
,使用它而不是 posix
不会 产生性能损失。此外,os
提供了一些附加功能,例如在 os.environ
中的条目更改时自动调用 putenv()
。
错误以异常的形式报告;通常的异常是针对类型错误给出的,而系统调用报告的错误会引发 OSError
。
大文件支持¶
多个操作系统(包括 AIX 和 Solaris)为大于 2 GiB 的文件提供支持,在 C 编程模型中,int 和 long 是 32 位值。这通常通过将相关大小和偏移类型定义为 64 位值来实现。此类文件有时称为大文件。
当 off_t
的大小大于 long,并且 long long 至少与 off_t
一样大时,Python 中会启用大文件支持。可能需要使用特定编译器标志配置并编译 Python 以启用此模式。例如,对于 Solaris 2.6 和 2.7,您需要执行类似以下操作
CFLAGS="`getconf LFS_CFLAGS`" OPT="-g -O2 $CFLAGS" \
./configure
在支持大文件的 Linux 系统上,这可能有效
CFLAGS='-D_LARGEFILE64_SOURCE -D_FILE_OFFSET_BITS=64' OPT="-g -O2 $CFLAGS" \
./configure
值得注意的模块内容¶
除了 os
模块文档中描述的许多函数外,posix
定义了以下数据项
- posix.environ¶
表示解释器启动时的字符串环境的字典。键和值在 Unix 上为字节,在 Windows 上为 str。例如,
environ[b'HOME']
(在 Windows 上为environ['HOME']
)是您的主目录的路径名,相当于 C 中的getenv("HOME")
。修改此字典不会影响
execv()
、popen()
或system()
传递的字符串环境;如果您需要更改环境,请将environ
传递给execve()
或将变量赋值和导出语句添加到system()
或popen()
的命令字符串中。在 3.2 版中更改:在 Unix 上,键和值是字节。
注意
os
模块提供了environ
的备用实现,它会在修改时更新环境。另请注意,更新os.environ
会使此字典过时。建议使用os
模块版本,而不是直接访问posix
模块。