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 编程模型中,intlong 是 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 模块。