sys模块
sys.argv 命令行参数
List
第一个元素是程序本身路径
sys.exit(n) 退出程序正常退出时exit(
0
)
sys.version 获取Python解释程序的版本信息
sys.maxint 最大的
Int
值
sys.path 返回模块的搜索路径初始化时使用PYTHONPATH环境变量的值
sys.platform 返回操作系统平台名称
sys.stdin 输入相关
sys.stdout 输出相关
sys.stderror 错误相关
os模块
os.getcwd() 获取当前工作目录即当前python脚本工作的目录路径
os.chdir(
"dirname"
) 改变当前脚本工作目录相当于shell下cd
os.curdir 返回当前目录: (
'.'
)
os.pardir 获取当前目录的父目录字符串名(
'..'
)
os.makedirs(
'dir1/dir2'
) 可生成多层递归目录
os.removedirs(
'dirname1'
) 若目录为空则删除并递归到上一级目录如若也为空则删除依此类推
os.mkdir(
'dirname'
) 生成单级目录相当于shell中mkdir dirname
os.rmdir(
'dirname'
) 删除单级空目录若目录不为空则无法删除报错相当于shell中rmdir dirname
os.listdir(
'dirname'
) 列出指定目录下的所有文件和子目录包括隐藏文件并以列表方式打印
os.remove() 删除一个文件
os.rename(
"oldname"
,
"new"
) 重命名文件
/
目录
os.stat(
'path/filename'
) 获取文件
/
目录信息
os.sep 操作系统特定的路径分隔符win下为
"\\",Linux下为"
/
"
os.linesep 当前平台使用的行终止符win下为
"\t\n"
,Linux下为
"\n"
os.pathsep 用于分割文件路径的字符串
os.name 字符串指示当前使用平台。win
-
>
'nt'
; Linux
-
>
'posix'
os.system(
"bash command"
) 运行shell命令直接显示
os.environ 获取系统环境变量
os.path.abspath(path) 返回path规范化的绝对路径
os.path.split(path) 将path分割成目录和文件名二元组返回
os.path.dirname(path) 返回path的目录。其实就是os.path.split(path)的第一个元素
os.path.basename(path) 返回path最后的文件名。如何path以或\结尾那么就会返回空值。即os.path.split(path)的第二个元素
os.path.exists(path) 如果path存在返回
True
如果path不存在返回
False
os.path.isabs(path) 如果path是绝对路径返回
True
os.path.isfile(path) 如果path是一个存在的文件返回
True
。否则返回
False
os.path.isdir(path) 如果path是一个存在的目录则返回
True
。否则返回
False
os.path.join(path1[, path2[, ...]]) 将多个路径组合后返回第一个绝对路径之前的参数将被忽略
os.path.getatime(path) 返回path所指向的文件或者目录的最后存取时间
os.path.getmtime(path) 返回path所指向的文件或者目录的最后修改时间
1 import os 2 #判断一个网络里在线IP有多少 3 for i in range(1,10): 4 ip = "172.18.4.%s" %i 5 #print(ip) 6 a = os.system("/bin/ping -c 1 %s > /dev/null 2>&1 && echo $?" %ip ) 7 #print(a) 8 if a == 0: 9 print( "%s UP" %ip)10 else:11 print("%s down" %ip)12 13 14 172.18.4.1 down15 172.18.4.2 down16 172.18.4.3 UP17 172.18.4.4 UP18 172.18.4.5 UP19 172.18.4.6 down20 172.18.4.7 down21 172.18.4.8 down22 172.18.4.9 down
json模块用于字符串 和 python数据类型间进行转换
编码把一个Python对象编码转换成Json字符串 json.dumps()
解码把Json格式字符串解码转换成Python对象 json.loads()
import jsona = {"k1":"v1","k2":"v2"}jack_a = json.dumps(a)print(jack_a)print(type(jack_a)){"k1": "v1", "k2": "v2"}
re模块常用正则表达式符号
'.' 默认匹配除\n之外的任意一个字符若指定flag DOTALL,则匹配任意字符包括换行'^' 匹配字符开头若指定flags MULTILINE,这种也可以匹配上(r"^a","\nabc\neee",flags=re.MULTILINE)'$' 匹配字符结尾或e.search("foo$","bfoo\nsdfsf",flags=re.MULTILINE).group()也可以'*' 匹配*号前的字符0次或多次re.findall("ab*","cabb3abcbbac") 结果为['abb', 'ab', 'a']'+' 匹配前一个字符1次或多次re.findall("ab+","ab+cd+abb+bba") 结果['ab', 'abb']'?' 匹配前一个字符1次或0次'{m}' 匹配前一个字符m次'{n,m}' 匹配前一个字符n到m次re.findall("ab{1,3}","abb abc abbcbbb") 结果'abb', 'ab', 'abb']'|' 匹配|左或|右的字符re.search("abc|ABC","ABCBabcCD").group() 结果'ABC''(...)' 分组匹配re.search("(abc){2}a(123|456)c", "abcabca456c").group() 结果 abcabca456c '\A' 只从字符开头匹配re.search("\Aabc","alexabc") 是匹配不到的'\Z' 匹配字符结尾同$'\d' 匹配数字0-9'\D' 匹配非数字'\w' 匹配[A-Za-z0-9]'\W' 匹配非[A-Za-z0-9]'s' 匹配空白字符、\t、\n、\r , re.search("\s+","ab\tc1\n3").group() 结果 '\t' '(?P...)' 分组匹配 re.search("(?P [0-9]{4})(?P [0-9]{2})(?P [0-9]{4})","371481199306143242").groupdict("city") 结果{'province': '3714', 'city': '81', 'birthday': '1993'}
图解
最常用的匹配语法
re.match 从头开始匹配re.search 匹配包含re.findall 把所有匹配到的字符放到以列表中的元素返回re.splitall 以匹配到的字符当做列表分隔符re.sub 匹配字符并替换
仅需轻轻知道的几个匹配模式
re.I(re.IGNORECASE): 忽略大小写括号内是完整写法下同M(MULTILINE): 多行模式改变'^'和'$'的行为参见上图S(DOTALL): 点任意匹配模式改变'.'的行为
本文出自http://www.cnblogs.com/fanyunpeng/p/6279057.html