python的OS库和正则表达式库

摘自:http://blog.chinaunix.net/uid-16360955-id-3351990.html 作留存学习

1.常用内置函数:(不用import就可以直接使用)

help(obj) 在线帮助, obj可是任何类型 
    callable(obj) 查看一个obj是不是可以像函数一样调用 
    repr(obj) 得到obj的表示字符串,可以利用这个字符串eval重建该对象的一个拷贝 
    eval_r(str) 表示合法的python表达式,返回这个表达式 
    dir(obj) 查看obj的name space中可见的name 
    hasattr(obj,name) 查看一个obj的name space中是否有name 
    getattr(obj,name) 得到一个obj的name space中的一个name 
    setattr(obj,name,value) 为一个obj的name space中的一个name指向vale这个object 
    delattr(obj,name) 从obj的name space中删除一个name 
    vars(obj) 返回一个object的name space。用dictionary表示 
    locals() 返回一个局部name space,用dictionary表示 
    globals() 返回一个全局name space,用dictionary表示 
    type(obj) 查看一个obj的类型 
    isinstance(obj,cls) 查看obj是不是cls的instance 
    issubclass(subcls,supcls) 查看subcls是不是supcls的子类 
    
  类型转换函数 
    chr(i) 把一个ASCII数值,变成字符 
    ord(i) 把一个字符或者unicode字符,变成ASCII数值 
    oct(x) 把整数x变成八进制表示的字符串 
    hex(x) 把整数x变成十六进制表示的字符串 
    str(obj) 得到obj的字符串描述 
    list(seq) 把一个sequence转换成一个list 
    tuple(seq) 把一个sequence转换成一个tuple 
    dict(),dict(list) 转换成一个dictionary 
    int(x) 转换成一个integer 
    long(x) 转换成一个long interger 
    float(x) 转换成一个浮点数 
    complex(x) 转换成复数 
    max(...) 求最大值 
    min(...) 求最小值 
  用于执行程序的内置函数 
    complie 如果一段代码经常要使用,那么先编译,再运行会更快。 
    
2.和操作系统相关的调用 
  系统相关的信息模块 import sys 
    sys.argv是一个list,包含所有的命令行参数. 
    sys.stdout sys.stdin sys.stderr 分别表示标准输入输出,错误输出的文件对象. 
    sys.stdin.readline() 从标准输入读一行 sys.stdout.write("a") 屏幕输出a 
    sys.exit(exit_code) 退出程序 
    sys.modules 是一个dictionary,表示系统中所有可用的module 
    sys.platform 得到运行的操作系统环境 
    sys.path 是一个list,指明所有查找module,package的路径. 
    
  操作系统相关的调用和操作 import os 
    os.environ 一个dictionary 包含环境变量的映射关系 os.environ["HOME"] 可以得到环境变量HOME的值 
    os.chdir(dir) 改变当前目录 os.chdir(‘d:\\outlook‘) 注意windows下用到转义 
    os.getcwd() 得到当前目录 
    os.getegid() 得到有效组id  os.getgid() 得到组id 
    os.getuid() 得到用户id  os.geteuid() 得到有效用户id 
    os.setegid os.setegid() os.seteuid() os.setuid() 
    os.getgruops() 得到用户组名称列表 
    os.getlogin() 得到用户登录名称 
    os.getenv 得到环境变量 
    os.putenv 设置环境变量 
    os.umask 设置umask 
    os.system(cmd) 利用系统调用,运行cmd命令 
    操作举例: 
      os.mkdir(‘/tmp/xx‘) os.system("echo ‘hello‘ > /tmp/xx/a.txt") os.listdir(‘/tmp/xx‘) 
      os.rename(‘/tmp/xx/a.txt‘,‘/tmp/xx/b.txt‘) os.remove(‘/tmp/xx/b.txt‘) os.rmdir(‘/tmp/xx‘) 
      用python编写一个简单的shell 
        #!/usr/bin/python 
        import os, sys 
        cmd = sys.stdin.readline() 
        while cmd: 
            os.system(cmd) 
            cmd = sys.stdin.readline() 
            
  用os.path编写平台无关的程序 
    os.path.abspath("1.txt") == os.path.join(os.getcwd(), "1.txt") 
    os.path.split(os.getcwd()) 用于分开一个目录名称中的目录部分和文件名称部分。 
    os.path.join(os.getcwd(), os.pardir, ‘a‘, ‘a.doc‘) 全成路径名称. 
      os.pardir 表示当前平台下上一级目录的字符 .. 
    os.path.getctime("/root/1.txt")  返回1.txt的ctime(创建时间)时间戳 
    os.path.exists(os.getcwd()) 判断文件是否存在 
    os.path.expanduser(‘~/dir‘) 把~扩展成用户根目录 
    os.path.expandvars(‘$PATH‘) 扩展环境变量PATH 
    os.path.isfile(os.getcwd()) 判断是否是文件名,1是0否 
    os.path.isdir(‘c:\Python26\temp‘) 判断是否是目录,1是0否 
    os.path.islink(‘/home/huaying/111.sql‘) 是否是符号连接 windows下不可用 
    os.path.ismout(os.getcwd()) 是否是文件系统安装点 windows下不可用 
    os.path.samefile(os.getcwd(), ‘/home/huaying‘) 看看两个文件名是不是指的是同一个文件 
    os.path.walk(‘/home/huaying‘, test_fun, "a.c")  
      遍历/home/huaying下所有子目录包括本目录,对于每个目录都会调用函数test_fun. 
      例:在某个目录中,和他所有的子目录中查找名称是a.c的文件或目录。 
        def test_fun(filename, dirname, names): //filename即是walk中的a.c dirname是访问的目录名称 
            if filename in names: //names是一个list,包含dirname目录下的所有内容 
                print os.path.join(dirname, filename) 
        os.path.walk(‘/home/huaying‘, test_fun, "a.c") 
        
  文件操作 
    打开文件 
      f = open("filename", "r") r只读 w写 rw读写 rb读二进制 wb写二进制 w+写追加 
    读写文件 
      f.write("a") f.write(str) 写一字符串 f.writeline() f.readlines() 与下read类同 
      f.read() 全读出来 f.read(size) 表示从文件中读取size个字符 
      f.readline() 读一行,到文件结尾,返回空串. f.readlines() 读取全部,返回一个list. list每个元素表示一行,包含"\n"\ 
      f.tell() 返回当前文件读取位置 
      f.seek(off, where) 定位文件读写位置. off表示偏移量,正数向文件尾移动,负数表示向开头移动。 
        where为0表示从开始算起,1表示从当前位置算,2表示从结尾算. 
      f.flush() 刷新缓存 
    关闭文件 
      f.close() 
      
  regular expression 正则表达式 import re 
    简单的regexp 
      p = re.compile("abc") if p.match("abc") : print "match" 
      上例中首先生成一个pattern(模式),如果和某个字符串匹配,就返回一个match object 
      除某些特殊字符metacharacter元字符,大多数字符都和自身匹配。 
      这些特殊字符是 。^ $ * + ? { [ ] \ | ( ) 
    字符集合(用[]表示) 
      列出字符,如[abc]表示匹配a或b或c,大多数metacharacter在[]中只表示和本身匹配。例: 
        a = ".^$*+?{\\|()"  大多数metachar在[]中都和本身匹配,但"^[]\"不同 
        p = re.compile("["+a+"]") 
        for i in a: 
            if p.match(i): 
                print "[%s] is match" %i 
            else: 
                print "[%s] is not match" %i 
        在[]中包含[]本身,表示"["或者"]"匹配.用\[和\]表示. 
        ^出现在[]的开头,表示取反.[^abc]表示除了a,b,c之外的所有字符。^没有出现在开头,即于身身匹配。 
        -可表示范围.[a-zA-Z]匹配任何一个英文字母。[0-9]匹配任何数字。 
        \在[]中的妙用。 
          \d [0-9] 
          \D [^0-9] 
          \s [ \t\n\r\f\v] 
          \S [^ \t\n\r\f\v] 
          \w [a-zA-Z0-9_] 
          \W [^a-zA-Z0-9_] 
          \t 表示和tab匹配, 其他的都和字符串的表示法一致 
          \x20 表示和十六进制ascii 0x20匹配 
          有了\,可以在[]中表示任何字符。注:单独的一个"."如果没有出现[]中,表示出了换行\n以外的匹配任何字符,类似[^\n]. 
      regexp的重复          
        {m,n}表示出现m个以上(含m个),n个以下(含n个).  如ab{1,3}c和abc,abbc,abbbc匹配,不会与ac,abbbc匹配。 
        m是下界,n是上界。m省略表下界是0,n省略,表上界无限大。 
        *表示{,} +表示{1,} ?表示{0,1} 
        最大匹配和最小匹配 python都是最大匹配,如果要最小匹配,在*,+,?,{m,n}后面加一个?. 
        match object的end可以得到匹配的最后一个字符的位置。 
          re.compile("a*").match(‘aaaa‘).end()     4  最大匹配 
          re.compile("a*?").match(‘aaaa‘).end()    0  最小匹配 
      使用原始字符串 
        字符串表示方法中用\\表示字符\.大量使用影响可读性。 
        解决方法:在字符串前面加一个r表示raw格式。 
        a = r"\a" print a 结果是\a 
        a = r"\"a" print a 结果是\"a 
      使用re模块 
        先用re.compile得到一个RegexObject 表示一个regexp 
        后用pattern的match,search的方法,得到MatchObject 
        再用match object得到匹配的位置,匹配的字符串等信息 
        RegxObject常用函数: 
          >>> re.compile("a").match("abab") 如果abab的开头和re.compile("a")匹配,得到MatchObject 
          <_sre.SRE_Match object at 0x81d43c8> 
          >>> print re.compile("a").match("bbab") 
          None 注:从str的开头开始匹配          
          >>> re.compile("a").search("abab") 在abab中搜索第一个和re_obj匹配的部分 
          <_sre.SRE_Match object at 0x81d43c8> 
          >>> print re.compile("a").search("bbab") 
          <_sre.SRE_Match object at 0x8184e18> 和match()不同,不必从开头匹配          
          re_obj.findall(str) 返回str中搜索所有和re_obj匹配的部分. 
            返回一个tuple,其中元素是匹配的字符串. 
        MatchObject的常用函数 
          m.start() 返回起始位置,m.end()返回结束位置(不包含该位置的字符). 
          m.span() 返回一个tuple表示(m.start(), m.end()) 
          m.pos(), m.endpos(), m.re(), m.string() 
            m.re().search(m.string(), m.pos(), m.endpos()) 会得到m本身 
          m.finditer()可以返回一个iterator,用来遍历所有找到的MatchObject. 
            for m in re.compile("[ab]").finditer("tatbxaxb"): 
            print m.span() 
      高级regexp 
        | 表示联合多个regexp. A B两个regexp,A|B表示和A匹配或者跟B匹配. 
        ^ 表示只匹配一行的开始行首,^只有在开头才有此特殊意义。 
        $ 表示只匹配一行的结尾 
        \A 表示只匹配第一行字符串的开头 ^匹配每一行的行首 
        \Z 表示只匹配行一行字符串的结尾 $匹配第一行的行尾 
        \b 只匹配词的边界 例:\binfo\b 只会匹配"info" 不会匹配information 
        \B 表示匹配非单词边界 
        示例如下: 
          >>> print re.compile(r"\binfo\b").match("info ") #使用raw格式 \b表示单词边界 
          <_sre.SRE_Match object at 0x817aa98> 
          >>> print re.compile("\binfo\b").match("info ") #没有使用raw \b表示退格符号 
          None 
          >>> print re.compile("\binfo\b").match("\binfo\b ") 
          <_sre.SRE_Match object at 0x8174948> 
      分组(Group) 示例:re.compile("(a(b)c)d").match("abcd").groups()   (‘abc‘, ‘b‘)        
        #!/usr/local/bin/python        
        import re        
        x = """ 
        name: Charles 
        Address: BUPT 
        
        name: Ann 
        Address: BUPT 
        """        
        #p = re.compile(r"^name:(.*)\n^Address:(.*)\n", re.M) 
        p = re.compile(r"^name:(?P.*)\n^Address:(?P .*)\n", re.M) 
        for m in p.finditer(x): 
                print m.span() 
                print "here is your friends list" 
                print "%s, %s"%m.groups() 
      Compile Flag 
        用re.compile得到RegxObject时,可以有一些flag用来调整RegxObject的详细特征. 
          DOTALL, S 让.匹配任意字符,包括换行符\n 
          IGNORECASE, I 忽略大小写 
          LOCALES, L 让\w \W \b \B和当前的locale一致 
          MULTILINE, M 多行模式,只影响^和$(参见上例) 
          VERBOSE, X verbose模式

时间: 2024-11-07 23:42:52

python的OS库和正则表达式库的相关文章

Python标准库01 正则表达式 (re包)

作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! 我将从正则表达式开始讲Python的标准库.正则表达式是文字处理中常用的工具,而且不需要额外的系统知识或经验.我们会把系统相关的包放在后面讲解. 正则表达式(regular expression)主要功能是从字符串(string)中通过特定的模式(pattern),搜索想要找到的内容. 语法 之前,我们简介了字符串相关的处理函数.我们可以通过这些函数实现简单的搜索功能,比如说从字

转 Python标准库01 正则表达式 (re包)

作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! 我将从正则表达式开始讲Python的标准库.正则表达式是文字处理中常用的工具,而且不需要额外的系统知识或经验.我们会把系统相关的包放在后面讲解. 正则表达式(regular expression)主要功能是从字符串(string)中通过特定的模式(pattern),搜索想要找到的内容. 语法 之前,我们简介了字符串相关的处理函数.我们可以通过这些函数实现简单的搜索功能,比如说从字

06 Python爬虫之Re(正则表达式)库

目录 一.正则表达式的语法 1.1 正则表达式的常用操作符 实例: 二.Re库的基本使用 2.1 Re库介绍 2.2 Re库主要功能函数 re.search(pattern,string,flags=0) re.match(pattern,string,flags=0) re.findall(pattern,string,flags=0) re.split(pattern,string,maxsplit=0,flags=0) re.finditer(pattern,string,flags=0)

Python学习笔记15:标准库之获取进程信息(os包)

Python的os包中有查询和修改进程信息的函数. 进程信息 os包中相关函数如下: uname() 返回操作系统相关信息,类似于Linux上的uname命令. umask() 设置该进程创建文件时的权限mask,类似于Linux上的umask命令. get*() 查询 (*由以下代替) uid, euid, resuid, gid, egid, resgid :权限相关,其中resuid主要用来返回saved UID. pid, pgid, ppid, sid                

Python标准库、第三方库和外部工具汇总

导读:Python数据工具箱涵盖从数据源到数据可视化的完整流程中涉及到的常用库.函数和外部工具.其中既有Python内置函数和标准库,又有第三方库和工具. 这些库可用于文件读写.网络抓取和解析.数据连接.数清洗转换.数据计算和统计分析.图像和视频处理.音频处理.数据挖掘/机器学习/深度学习.数据可视化.交互学习和集成开发以及其他Python协同数据工作工具. 为了区分不同对象的来源和类型,本文将在描述中通过以下方法进行标识: Python内置函数:Python自带的内置函数.函数无需导入,直接使

Python 标准库、第三方库

Python数据工具箱涵盖从数据源到数据可视化的完整流程中涉及到的常用库.函数和外部工具.其中既有Python内置函数和标准库,又有第三方库和工具.这些库可用于文件读写.网络抓取和解析.数据连接.数清洗转换.数据计算和统计分析.图像和视频处理.音频处理.数据挖掘/机器学习/深度学习.数据可视化.交互学习和集成开发以及其他Python协同数据工作工具. 为了区分不同对象的来源和类型,本节将在描述中通过以下方法进行标识: [Python内置函数]:Python自带的内置函数.函数无需导入,直接使用.

日月累积的整理!140种Python标准库、第三方库和外部工具都有了

Python数据工具箱涵盖从数据源到数据可视化的完整流程中涉及到的常用库.函数和外部工具.其中既有Python内置函数和标准库,又有第三方库和工具. 读者福利,想要了解python人工智能可直接点击链接即可领取相关学习福利包:石墨文档 是安全网站放心,继续访问就可以领取了哦 这些库可用于文件读写.网络抓取和解析.数据连接.数清洗转换.数据计算和统计分析.图像和视频处理.音频处理.数据挖掘/机器学习/深度学习.数据可视化.交互学习和集成开发以及其他Python协同数据工作工具. 为了区分不同对象的

python 常用的标准库及第三方库

标准库Python拥有一个强大的标准库.Python语言的核心只包含数字.字符串.列表.字典.文件等常见类型和函数,而由Python标准库提供了系统管理.网络通信.文本处理.数据库接口.图形系统.XML处理等额外的功能.Python标准库的主要功能有:1.文本处理,包含文本格式化.正则表达式匹配.文本差异计算与合并.Unicode支持,二进制数据处理等功能2.文件处理,包含文件操作.创建临时文件.文件压缩与归档.操作配置文件等功能3.操作系统功能,包含线程与进程支持.IO复用.日期与时间处理.调

Python标准库与第三方库详解(转载)

转载地址: http://www.codeweblog.com/python%e6%a0%87%e5%87%86%e5%ba%93%e4%b8%8e%e7%ac%ac%e4%b8%89%e6%96%b9%e5%ba%93%e8%af%a6%e8%a7%a3/ 这篇文章主要介绍了Python标准库与第三方库,需要的朋友可以参考下 本文详细罗列并说明了Python的标准库与第三方库如下,供对此有需要的朋友进行参考: Tkinter———— Python默认的图形界面接口.Tkinter是一个和Tk接