python常用模块详解

编程

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下为"

",Linux下为"

"

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所指向的文件或者目录的最后修改时间

 

 1import os

2 #判断一个网络里在线IP有多少

3for 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)

8if a == 0:

9print( "%s UP" %ip)

10else:

11print("%s down" %ip)

12

13

14 172.18.4.1 down

15 172.18.4.2 down

16 172.18.4.3 UP

17 172.18.4.4 UP

18 172.18.4.5 UP

19 172.18.4.6 down

20 172.18.4.7 down

21 172.18.4.8 down

22 172.18.4.9 down

 

 

 

json模块,用于字符串 和 python数据类型间进行转换

  • 编码:把一个Python对象编码转换成Json字符串   json.dumps()
  • 解码:把Json格式字符串解码转换成Python对象   json.loads()

import json

a = {"k1":"v1","k2":"v2"}

jack_a = json.dumps(a)

print(jack_a)

print(type(jack_a))

{"k1": "v1", "k2": "v2"}

<class"str">

 

 re模块,常用正则表达式符号

"."     默认匹配除

之外的任意一个字符,若指定flag DOTALL,则匹配任意字符,包括换行

"^" 匹配字符开头,若指定flags MULTILINE,这种也可以匹配上(r"^a","

abc

eee",flags=re.MULTILINE)

"$" 匹配字符结尾,或e.search("foo$","bfoo

sdfsf",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") 是匹配不到的

"" 匹配字符结尾,同$

"d" 匹配数字0-9

"D" 匹配非数字

"w" 匹配[A-Za-z0-9]

"W" 匹配非[A-Za-z0-9]

"s" 匹配空白字符、 、

、 , re.search("s+","ab c1

3").group() 结果 ""

"(?P<name>...)" 分组匹配 re.search("(?P<province>[0-9]{4})(?P<city>[0-9]{2})(?P<birthday>[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): 点任意匹配模式,改变"."的行为

以上是 python常用模块详解 的全部内容, 来源链接: utcz.com/z/514988.html

回到顶部