龙盟编程博客 | 无障碍搜索 | 云盘搜索神器
快速搜索
主页 > web编程 > python编程 >

Python常用模块用法分析(2)

时间:2014-09-09 02:16来源:网络整理 作者:网络 点击:
分享到:
例:在某个目录中,和他所有的子目录中查找名称是a.c的文件或目录: def test_fun(filename, dirname, names): //filename即是walk中的a.c dirname是访问的目录名称 if f

例:在某个目录中,和他所有的子目录中查找名称是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")

文件操作

1.打开文件

f = open("filename", "r") r只读 w写 rw读写 rb读二进制 wb写二进制 w+写追加

2.读写文件

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() 刷新缓存

3.关闭文件
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的常用函数

精彩图集

赞助商链接