飞翔飞翔
主页
  • 计算机基础

    • TCP/IP协议
    • Linux命令
  • 数据库

    • SQL教程
  • 编程语言

    • C语言
    • Python2
    • Python3
  • 数据格式

    • JSON教程
  • 工具

    • Markdown指南
  • Git

    • GitFlow
  • Quartz

    • Quartz教程
  • Java

    • Java设计模式
  • 缓存

    • Redis教程
联系
阿里云
主页
  • 计算机基础

    • TCP/IP协议
    • Linux命令
  • 数据库

    • SQL教程
  • 编程语言

    • C语言
    • Python2
    • Python3
  • 数据格式

    • JSON教程
  • 工具

    • Markdown指南
  • Git

    • GitFlow
  • Quartz

    • Quartz教程
  • Java

    • Java设计模式
  • 缓存

    • Redis教程
联系
阿里云
  • 学习路径
  • 第1章 认识Python

    • Python 历史与特点
    • Python 2 与 Python 3 的核心差异
    • 安装与运行 Python 2.7.18
    • 编码规范 PEP 8
  • 第2章 基础语法

    • 变量与对象
    • 数字类型
    • 字符串 str
    • Unicode 字符串
    • 运算符
    • 空值 None
  • 第3章 流程控制

    • if 条件语句
    • if-else 条件语句
    • if-elif-else 多分支
    • 条件表达式(三元运算符)
    • while 循环
    • for 循环
    • range 与 xrange
    • 循环控制:break、continue、pass
    • 循环 else 子句
  • 第4章 数据结构

    • 列表基础
    • 列表方法
    • 列表推导式
    • 元组
    • 字典基础
    • 字典方法
    • 字典循环技巧
    • 集合
    • 序列解包
    • 序列比较
  • 第5章 函数

    • 定义函数
    • 参数传递机制
    • 默认参数
    • 关键字参数
    • 可变参数
    • Lambda 表达式
    • 文档字符串
    • 函数对象
  • 第6章 模块与包

    • import 导入
    • 模块搜索路径
    • name 与主程序
    • 编译文件 .pyc 与 .pyo
    • 包结构
    • dir() 函数
  • 第7章 文件与IO

    • 打开与关闭文件
    • 文件读写方法
    • with 上下文管理器
    • 格式化输出:% 操作符
    • 格式化输出:str.format()
    • JSON 序列化
  • 第8章 面向对象

    • 类定义与实例化
    • init 构造方法
    • 类变量与实例变量
    • 方法调用与 self
    • 继承基础
    • 多重继承
    • 新式类与旧式类
    • 私有变量与名称改写
    • 属性装饰器 property
    • 类方法与静态方法
    • 魔术方法
    • 空类与数据记录
  • 第9章 异常处理

    • 异常类型
    • try-except
    • try-except-else-finally
    • 抛出异常 raise
    • 自定义异常
    • with 语句与上下文管理器
  • 第10章 迭代器与生成器

    • 迭代器协议
    • 生成器函数
    • 生成器表达式
    • itertools模块
  • 第11章 标准库精要

    • os模块
    • sys模块
    • datetime模块
    • re模块
    • json模块
    • collections模块
    • math与random模块
    • urllib2与网络请求
    • subprocess与命令执行
    • threading与并发
    • unittest与测试
    • 虚拟环境与包管理
  • 第12章 工程实践

    • 调试技巧
    • 性能分析
    • 文档与注释
    • 下一步学习

sys模块

sys 模块提供了与 Python 解释器和系统环境交互的接口。它包含命令行参数、路径配置、标准输入输出、解释器信息等功能,是编写脚本和工具时最常用的模块之一。

命令行参数

sys.argv 是一个列表,包含命令行传入的所有参数:

import sys

print sys.argv

运行 python script.py arg1 arg2:

['script.py', 'arg1', 'arg2']
  • sys.argv[0] 是脚本名
  • sys.argv[1:] 是用户传入的参数

实际应用:

import sys

def main():
    if len(sys.argv) < 2:
        print "Usage: python script.py <filename>"
        sys.exit(1)
    
    filename = sys.argv[1]
    with open(filename, "r") as f:
        print f.read()

if __name__ == "__main__":
    main()

退出程序

sys.exit() 终止程序并返回状态码:

import sys

sys.exit(0)       # 正常退出
sys.exit(1)       # 异常退出(非零表示错误)
sys.exit("Error message")   # 退出并打印消息

sys.exit() 抛出 SystemExit 异常,可以被捕获:

try:
    sys.exit(1)
except SystemExit as e:
    print "Exit code:", e.code

路径配置

sys.path 是模块搜索路径列表:

import sys

print sys.path
# ['', '/usr/lib/python2.7', '/usr/lib/python2.7/plat-linux2', ...]
  • 第一个空字符串表示当前目录
  • 可以动态添加路径:
sys.path.insert(0, "/path/to/my/modules")
import my_module

注意:修改 sys.path 只在当前进程有效。更好的做法是通过 PYTHONPATH 环境变量或 .pth 文件配置。

标准输入输出

import sys

print sys.stdin          # <open file '<stdin>', mode 'r'>
print sys.stdout         # <open file '<stdout>', mode 'w'>
print sys.stderr         # <open file '<stderr>', mode 'w'>

重定向输出:

# 写入文件
sys.stdout = open("output.txt", "w")
print "This goes to file"
sys.stdout = sys.__stdout__   # 恢复

打印错误信息:

import sys

print >>sys.stderr, "Error: something went wrong"

>> 语法将输出重定向到指定文件对象。错误信息应该输出到 stderr,这样用户可以通过 shell 重定向分离正常输出和错误:

python script.py > output.log 2> error.log

解释器信息

import sys

print sys.version        # Python 版本信息
print sys.version_info   # (2, 7, 18, 'final', 0) —— 版本号元组
print sys.platform       # 'linux2', 'win32', 'darwin'
print sys.maxint         # 2147483647(32位)或更大(64位)
print sys.maxsize        # 最大列表/字符串大小
print sys.getsizeof(1)   # 对象内存占用(字节)

版本检查:

import sys

if sys.version_info < (2, 7):
    print "Python 2.7+ required"
    sys.exit(1)

模块信息

import sys

print sys.modules        # 已加载模块的字典
print "os" in sys.modules    # True

print sys.getrefcount("hello")   # 对象的引用计数

递归限制

import sys

print sys.getrecursionlimit()    # 默认 1000
sys.setrecursionlimit(2000)      # 设置递归深度限制

防止无限递归导致栈溢出。注意:设置过高可能导致 C 栈溢出,程序崩溃。

实际应用

跨平台换行符:

import sys

if sys.platform == "win32":
    newline = "\r\n"
elif sys.platform == "darwin":
    newline = "\r"
else:
    newline = "\n"

实际上,os.linesep 已经提供了这个值,但 sys.platform 在需要更细粒度判断时有用。

脚本路径处理:

import sys
import os

# 获取脚本所在目录
script_dir = os.path.dirname(os.path.abspath(sys.argv[0]))
config_path = os.path.join(script_dir, "config.ini")

处理管道输入:

import sys

if not sys.stdin.isatty():
    # 从管道读取
    for line in sys.stdin:
        process(line)
else:
    # 交互式运行
    data = raw_input("Enter data: ")
    process(data)

sys 与 os 的选择

需求推荐模块
文件路径操作os.path
环境变量os.environ
命令行参数sys.argv
退出程序sys.exit()
标准输入输出sys.stdin/stdout/stderr
模块路径sys.path
版本信息sys.version_info
上一页
os模块
下一页
datetime模块