正则表达式 re sys os random time 模块
今天學(xué)習(xí)內(nèi)容如下:
1.正則表達(dá)式
百度正則表達(dá)式在線測試,可以練習(xí)
正則表達(dá)式本身也和python沒有什么關(guān)系,就是匹配字符串內(nèi)容的一種規(guī)則。官方定義:正則表達(dá)式是對字符串操作的一種邏輯公式,就是用事先定義好的一些特定字符、及這些特定字符的組合,組成一個(gè)“規(guī)則字符串”,這個(gè)“規(guī)則字符串”用來表達(dá)對字符串的一種過濾邏輯。re模塊本質(zhì)上和正則表達(dá)式?jīng)]有一毛錢的關(guān)系。re模塊和正則表達(dá)式的關(guān)系 類似于 time模塊和時(shí)間的關(guān)系你沒有學(xué)習(xí)python之前,也不知道有一個(gè)time模塊,但是你已經(jīng)認(rèn)識時(shí)間了 12:30就表示中午十二點(diǎn)半(這個(gè)時(shí)間可好,一般這會兒就該下課了)。時(shí)間有自己的格式,年月日時(shí)分秒,12個(gè)月,365天......已經(jīng)成為了一種規(guī)則。你也早就牢記于心了。time模塊只不過是python提供給我們的可以方便我們操作時(shí)間的一個(gè)工具而已。
字符組;在同一個(gè)位置可能出現(xiàn)的各種字符組成了一個(gè)字符組,在正則表達(dá)式中用[]表示
?
?
?
2.re 模塊
import re # ret = re.findall('[a-z]+','eva egon yuan') # print(ret) # 返回所有滿足匹配條件的結(jié)果,放在列表里# ret = re.search('a','eva egon yuan') # # print(ret) # print(ret.group()) # 從前往后,找到一個(gè)就返回,返回的變量需要調(diào)用group才能拿到結(jié)果 # 如果沒有找到,那么返回None,調(diào)用group會報(bào)錯(cuò) # ret = re.match('e','eva egon yuan') # print(ret.group()) # match是從頭開始匹配,如果正則規(guī)則從頭開始可以匹配上,就返回一個(gè)變量。 # 匹配的內(nèi)容需要用group才能顯示 # 如果沒匹配上,就返回None,調(diào)用group會報(bào)錯(cuò) # ret = re.split('[ab]','eva egon yuan',1) # ret = re.split('[ab]','ava egon yuan',1) # ret = re.split('[ab]','ava egon yuan') # print(ret) # # 先按'a'分割得到''和'bcd',在對''和'bcd'分別按'b'分割 # # ret = re.sub('\d', 'H', 'eva3egon4yuan4',1) # # 將數(shù)字替換成'H',參數(shù)1表示只替換1個(gè) # print(ret) #evaHegon4yuan4# ret = re.subn('\d', 'H', 'eva3egon4yuan4') # #將數(shù)字替換成'H',返回元組(替換的結(jié)果,替換了多少次) # print(ret) # # obj = re.compile('\d{3}') # # #將正則表達(dá)式編譯成為一個(gè) 正則表達(dá)式對象,規(guī)則要匹配的是3個(gè)數(shù)字 # # ret = obj.search('abc123456eeee') #正則表達(dá)式對象調(diào)用search,參數(shù)為待匹配的字符串 # # print(ret.group()) # ret = obj.search('abcashgjgsdghkash456eeee3wr2') #正則表達(dá)式對象調(diào)用search,參數(shù)為待匹配的字符串 # print(ret.group()) #結(jié)果 : 123 re模塊下的常用方法?
# import re # ret = re.finditer('\d','dsdkfsf123dlll') # print(ret) # print(next(ret).group()) # print(next(ret).group()) # for i in ret: # print(i.group()) # # import re # ret = re.search('^([1-9])(\d{14})(\d{2}[0-9x])?$','110105199912122277') # print(ret) # # print(ret.group(1)) # print(ret.group(2)) # print(ret.group(3))# import re # ret = re.findall('www.(baidu|oldboy)\.com', 'www.oldboy.com') # print(ret) # ['oldboy'] # # import re # ret = re.findall('www.(?:baidu|oldboy)\.com', 'www.oldboy.com') # print(ret) # ['www.oldboy.com'] import re # ret=re.split("\d+","eva3egon4yuan") # print(ret) #結(jié)果 : ['eva', 'egon', 'yuan'] ret=re.split("(\d+)","eva3egon4yuan") print(ret) #結(jié)果 : ['eva', '3', 'egon', '4', 'yuan'] 分組的特別用法group(1)和?: import re print(re.findall('.\d','34')) print(re.findall('.\d','\n4')) print(re.findall('.\d','\n4',re.S))?
import re # print(re.findall('\\\\s','\s')) # print(re.findall(r'\\n',r'\nhfh'))# ret = search('\d(\w)+','awir17948jsdc') ret = re.search('\d(?P<name>\w\d)+','awir17948jsdcm') # 找整個(gè)字符串,遇到匹配上的就返回,遇不到就None # 如果有返回值ret.group()就可以取到值 # 取分組中的內(nèi)容 : ret.group(1) / ret.group('name') print(ret.group('name')) print(ret.group(1))print(ret.group()) 補(bǔ)充 import reret = re.search("<(?P<tag_name>\w+)>\w+</(?P=tag_name)>","<h1>hello</h1>") #還可以在分組中利用?<name>的形式給分組起名字 #獲取的匹配結(jié)果可以直接用group('名字')拿到對應(yīng)的值 print(ret.group('tag_name')) #結(jié)果 :h1 print(ret.group()) #結(jié)果 :<h1>hello</h1> ret = re.search(r"<(\w+)>\w+</\1>","<h1>hello</h1>") #如果不給組起名字,也可以用\序號來找到對應(yīng)的組,表示要找的內(nèi)容和前面的組內(nèi)容一致 #獲取的匹配結(jié)果可以直接用group(序號)拿到對應(yīng)的值 print(ret.group(1)) print(ret.group()) #結(jié)果 :<h1>hello</h1> 匹配標(biāo)簽 import reret=re.findall("\d+","1-2*(60+(-40.35/5)-(-4*3))") print(ret) #['1', '2', '60', '40', '35', '5', '4', '3'] ret=re.findall("-?\d+\.\d*|(-?\d+)","1-2*(60+(-40.35/5)-(-4*3))") print(ret) #['1', '-2', '60', '', '5', '-4', '3'] ret.remove("") print(ret) #['1', '-2', '60', '5', '-4', '3'] 匹配整數(shù)3.模塊
什么是模塊?
? ?常見的場景:一個(gè)模塊就是一個(gè)包含了python定義和聲明的文件,文件名就是模塊名字加上.py的后綴。
? ?但其實(shí)import加載的模塊分為四個(gè)通用類別:
1 使用python編寫的代碼(.py文件)
2 已被編譯為共享庫或DLL的C或C++擴(kuò)展
3 包好一組模塊的包
4 使用C編寫并鏈接到python解釋器的內(nèi)置模塊
為何要使用模塊?
? ?如果你退出python解釋器然后重新進(jìn)入,那么你之前定義的函數(shù)或者變量都將丟失,因此我們通常將程序?qū)懙轿募幸员阌谰帽4嫦聛?#xff0c;需要時(shí)就通過python test.py方式去執(zhí)行,此時(shí)test.py被稱為腳本script。
? ? 隨著程序的發(fā)展,功能越來越多,為了方便管理,我們通常將程序分成一個(gè)個(gè)的文件,這樣做程序的結(jié)構(gòu)更清晰,方便管理。這時(shí)我們不僅僅可以把這些文件當(dāng)做腳本去執(zhí)行,還可以把他們當(dāng)做模塊來導(dǎo)入到其他的模塊中,實(shí)現(xiàn)了功能的重復(fù)利用,
?
4.collections模塊
在內(nèi)置數(shù)據(jù)類型(dict、list、set、tuple)的基礎(chǔ)上,collections模塊還提供了幾個(gè)額外的數(shù)據(jù)類型:Counter、deque、defaultdict、namedtuple和OrderedDict等。
1.namedtuple: 生成可以使用名字來訪問元素內(nèi)容的tuple
2.deque: 雙端隊(duì)列,可以快速的從另外一側(cè)追加和推出對象
3.Counter: 計(jì)數(shù)器,主要用來計(jì)數(shù)
4.OrderedDict: 有序字典
5.defaultdict: 帶有默認(rèn)值的字典
#namedtuple('名稱', [屬性list]): from collections import namedtuple # Point = namedtuple('point',['x','y','z']) # p1 = Point(1,2,3) # p2 = Point(1,2,3) # print(p1.x) # print(p1.y) # print(p1,p2)#花色和數(shù)字 # Card = namedtuple('card',['suits','number']) # c1 = Card('紅桃',2) # print(c1) # print(c1.number) # print(c1.suits) namedtuple 使用list存儲數(shù)據(jù)時(shí),按索引訪問元素很快,但是插入和刪除元素就很慢了,因?yàn)閘ist是線性存儲,數(shù)據(jù)量大的時(shí)候,插入和刪除效率很低。deque是為了高效實(shí)現(xiàn)插入和刪除操作的雙向列表,適合用于隊(duì)列和棧:#隊(duì)列(先進(jìn)先出 FIFO) # import queue # q = queue.Queue() # q.put(10) # q.put(5) # q.put(6) # print(q) # print(q.get()) # print(q.get()) # # print(q.get()) # # print(q.get())#阻塞 # print(q.qsize())from collections import deque dq = deque([1,2]) dq.append('a')# 從后面放數(shù)據(jù) [1,2,'a'] dq.appendleft('b')#從前面放數(shù)據(jù)['b',1,2,'a'] dq.insert(2,3)#['b',1,3,2,'a'] print(dq.pop())# 從后面取數(shù)據(jù) print(dq.pop())# 從后面取數(shù)據(jù) print(dq.popleft())#從前面取數(shù)據(jù) print(dq) deque 使用dict時(shí),Key是無序的。在對dict做迭代時(shí),我們無法確定Key的順序。如果要保持Key的順序,可以用OrderedDict:# d = dict([('a', 1), ('b', 2), ('c', 3)]) # print(d) # dict的Key是無序的 from collections import OrderedDict od = OrderedDict([('a',1),('b',2),('c',3)]) print(od) # OrderedDict的Key是有序的 print(od['a']) for k in od:print(k) OrderedDict 使用dict時(shí),如果引用的Key不存在,就會拋出KeyError。如果希望key不存在時(shí),返回一個(gè)默認(rèn)值,就可以用defaultdict:有如下值集合 [11,22,33,44,55,66,77,88,99,90...],將所有大于 66 的值保存至字典的第一個(gè)key中,將小于 66 的值保存至第二個(gè)key的值中。即: {'k1': 大于66 , 'k2': 小于66}示例一values = [11, 22, 33,44,55,66,77,88,99,90]my_dict = {}for value in values:if value>66:if my_dict.has_key('k1'):my_dict['k1'].append(value)else:my_dict['k1'] = [value]else:if my_dict.has_key('k2'):my_dict['k2'].append(value)else:my_dict['k2'] = [value] 使用dict時(shí),如果引用的Key不存在,就會拋出KeyError。如果希望key不存在時(shí),返回一個(gè)默認(rèn)值,就可以用defaultdict:示例二 from collections import defaultdictvalues = [11, 22, 33,44,55,66,77,88,99,90]d = defaultdict(lambda :109) d = defaultdict(10)#TypeError: first argument must be callable or None print(d) print(d['m']) print(d['a']) print(d) # my_dict = defaultdict(list) # print(my_dict['k1']) # for value in values: # if value>66: # my_dict['k1'].append(value) # else: # my_dict['k2'].append(value) # print(my_dict) defaultdict Counter類的目的是用來跟蹤值出現(xiàn)的次數(shù)。它是一個(gè)無序的容器類型,以字典的鍵值對形式存儲,其中元素作為key,其計(jì)數(shù)作為value。計(jì)數(shù)值可以是任意的Interger(包括0和負(fù)數(shù))。Counter類和其他語言的bags或multisets很相似。 c = Counter('abcdeabcdabcaba') print c 輸出:Counter({'a': 5, 'b': 4, 'c': 3, 'd': 2, 'e': 1}) Counter5.time 模塊
#常用方法
1.time.sleep(secs)
(線程)推遲指定的時(shí)間運(yùn)行。單位為秒。
2.time.time()
獲取當(dāng)前時(shí)間戳
表示時(shí)間的三種方式
在Python中,通常有這三種方式來表示時(shí)間:時(shí)間戳、元組(struct_time)、格式化的時(shí)間字符串:
(1)時(shí)間戳(timestamp) :通常來說,時(shí)間戳表示的是從1970年1月1日00:00:00開始按秒計(jì)算的偏移量。我們運(yùn)行“type(time.time())”,返回的是float類型。(給計(jì)算機(jī)看的)
(2)格式化的時(shí)間字符串(Format String): ‘1999-12-06’(給人看的)
?
%y 兩位數(shù)的年份表示(00-99) %Y 四位數(shù)的年份表示(000-9999) %m 月份(01-12) %d 月內(nèi)中的一天(0-31) %H 24小時(shí)制小時(shí)數(shù)(0-23) %I 12小時(shí)制小時(shí)數(shù)(01-12) %M 分鐘數(shù)(00=59) %S 秒(00-59) %a 本地簡化星期名稱 %A 本地完整星期名稱 %b 本地簡化的月份名稱 %B 本地完整的月份名稱 %c 本地相應(yīng)的日期表示和時(shí)間表示 %j 年內(nèi)的一天(001-366) %p 本地A.M.或P.M.的等價(jià)符 %U 一年中的星期數(shù)(00-53)星期天為星期的開始 %w 星期(0-6),星期天為星期的開始 %W 一年中的星期數(shù)(00-53)星期一為星期的開始 %x 本地相應(yīng)的日期表示 %X 本地相應(yīng)的時(shí)間表示 %Z 當(dāng)前時(shí)區(qū)的名稱 %% %號本身 View Code?
(3)結(jié)構(gòu)化時(shí)間-元組(struct_time) :struct_time元組共有9個(gè)元素共九個(gè)元素:(年,月,日,時(shí),分,秒,一年中第幾周,一年中第幾天等)(元組則是用來操作時(shí)間的)
import time# print(time.strftime('%y-%m-%d %H-%M-%S')) # print(time.strftime('%Y-%m-%d %H-%M-%S')) # print(time.strftime('%Y/%m/%d %H-%M-%S')) # print(time.strftime('%Y:%m:%d %H-%M-%S')) # print(time.strftime('%Y-%m-%d %X')) struct_time = time.localtime() print(struct_time) print(struct_time.tm_year) 示例?
import time# 時(shí)間戳和結(jié)構(gòu)化時(shí)間轉(zhuǎn)換 #時(shí)間戳-->結(jié)構(gòu)化時(shí)間 #time.gmtime(時(shí)間戳) #UTC時(shí)間,與英國倫敦當(dāng)?shù)貢r(shí)間一致 #time.localtime(時(shí)間戳) #當(dāng)?shù)貢r(shí)間。例如我們現(xiàn)在在北京執(zhí)行這個(gè)方法:與UTC時(shí)間相差8小時(shí),UTC時(shí)間+8小時(shí) = 北京時(shí)間 # t = time.time() # print(t) # print(time.localtime(1500000000)) # print(time.localtime(t)) # print(time.localtime()) # print(time.gmtime(t)) #時(shí)間戳<--結(jié)構(gòu)化時(shí)間 # print(time.mktime(time.localtime()))#格式化時(shí)間--》結(jié)構(gòu)化時(shí)間 # print(time.strptime('2000-12.31','%Y-%m.%d')) #格式化時(shí)間《--結(jié)構(gòu)化時(shí)間 print(time.strftime('%m/%d/%Y %H:%M:%S',time.localtime())) 幾種格式之間的轉(zhuǎn)換 #結(jié)構(gòu)化時(shí)間 --> %a %b %d %H:%M:%S %Y串 #time.asctime(結(jié)構(gòu)化時(shí)間) 如果不傳參數(shù),直接返回當(dāng)前時(shí)間的格式化串 >>>time.asctime(time.localtime(1500000000)) 'Fri Jul 14 10:40:00 2017' >>>time.asctime() 'Mon Jul 24 15:18:33 2017'#時(shí)間戳 --> %a %d %d %H:%M:%S %Y串 #time.ctime(時(shí)間戳) 如果不傳參數(shù),直接返回當(dāng)前時(shí)間的格式化串 >>>time.ctime() 'Mon Jul 24 15:19:07 2017' >>>time.ctime(1500000000) 'Fri Jul 14 10:40:00 2017' 幾種格式轉(zhuǎn)換 import time true_time=time.mktime(time.strptime('2017-09-11 08:30:00','%Y-%m-%d %H:%M:%S')) time_now=time.mktime(time.strptime('2017-09-12 11:00:00','%Y-%m-%d %H:%M:%S')) dif_time=time_now-true_time struct_time=time.gmtime(dif_time) print('過去了%d年%d月%d天%d小時(shí)%d分鐘%d秒'%(struct_time.tm_year-1970,struct_time.tm_mon-1,struct_time.tm_mday-1,struct_time.tm_hour,struct_time.tm_min,struct_time.tm_sec)) 計(jì)算時(shí)間差?6.random模塊
>>> import random #隨機(jī)小數(shù) >>> random.random() # 大于0且小于1之間的小數(shù) 0.7664338663654585 >>> random.uniform(1,3) #大于1小于3的小數(shù) 1.6270147180533838 #恒富:發(fā)紅包#隨機(jī)整數(shù) >>> random.randint(1,5) # 大于等于1且小于等于5之間的整數(shù) >>> random.randrange(1,10,2) # 大于等于1且小于10之間的奇數(shù)#隨機(jī)選擇一個(gè)返回 >>> random.choice([1,'23',[4,5]]) # #1或者23或者[4,5] #隨機(jī)選擇多個(gè)返回,返回的個(gè)數(shù)為函數(shù)的第二個(gè)參數(shù) >>> random.sample([1,'23',[4,5]],2) # #列表元素任意2個(gè)組合 [[4, 5], '23']#打亂列表順序 >>> item=[1,3,5,7,9] >>> random.shuffle(item) # 打亂次序 >>> item [5, 1, 3, 7, 9] >>> random.shuffle(item) >>> item [5, 9, 7, 1, 3] 示例 import randomdef v_code():code = ''for i in range(5):num=random.randint(0,9)alf=chr(random.randint(65,90))add=random.choice([num,alf])code="".join([code,str(add)])return codeprint(v_code()) 生成隨機(jī)驗(yàn)證碼?7.os模塊
os模塊是與操作系統(tǒng)交互的一個(gè)接口
''' os.getcwd() 獲取當(dāng)前工作目錄,即當(dāng)前python腳本工作的目錄路徑 os.chdir("dirname") 改變當(dāng)前腳本工作目錄;相當(dāng)于shell下cd os.curdir 返回當(dāng)前目錄: ('.') os.pardir 獲取當(dāng)前目錄的父目錄字符串名:('..') os.makedirs('dirname1/dirname2') 可生成多層遞歸目錄 os.removedirs('dirname1') 若目錄為空,則刪除,并遞歸到上一級目錄,如若也為空,則刪除,依此類推 os.mkdir('dirname') 生成單級目錄;相當(dāng)于shell中mkdir dirname os.rmdir('dirname') 刪除單級空目錄,若目錄不為空則無法刪除,報(bào)錯(cuò);相當(dāng)于shell中rmdir dirname os.listdir('dirname') 列出指定目錄下的所有文件和子目錄,包括隱藏文件,并以列表方式打印 os.remove() 刪除一個(gè)文件 os.rename("oldname","newname") 重命名文件/目錄 os.stat('path/filename') 獲取文件/目錄信息 os.sep 輸出操作系統(tǒng)特定的路徑分隔符,win下為"\\",Linux下為"/" os.linesep 輸出當(dāng)前平臺使用的行終止符,win下為"\t\n",Linux下為"\n" os.pathsep 輸出用于分割文件路徑的字符串 win下為;,Linux下為: os.name 輸出字符串指示當(dāng)前使用平臺。win->'nt'; Linux->'posix' os.system("bash command") 運(yùn)行shell命令,直接顯示 os.popen("bash command).read() 運(yùn)行shell命令,獲取執(zhí)行結(jié)果 os.environ 獲取系統(tǒng)環(huán)境變量os.path os.path.abspath(path) 返回path規(guī)范化的絕對路徑 os.path.split(path) 將path分割成目錄和文件名二元組返回 os.path.dirname(path) 返回path的目錄。其實(shí)就是os.path.split(path)的第一個(gè)元素 os.path.basename(path) 返回path最后的文件名。如何path以/或\結(jié)尾,那么就會返回空值。即os.path.split(path)的第二個(gè)元素 os.path.exists(path) 如果path存在,返回True;如果path不存在,返回False os.path.isabs(path) 如果path是絕對路徑,返回True os.path.isfile(path) 如果path是一個(gè)存在的文件,返回True。否則返回False os.path.isdir(path) 如果path是一個(gè)存在的目錄,則返回True。否則返回False os.path.join(path1[, path2[, ...]]) 將多個(gè)路徑組合后返回,第一個(gè)絕對路徑之前的參數(shù)將被忽略 os.path.getatime(path) 返回path所指向的文件或者目錄的最后訪問時(shí)間 os.path.getmtime(path) 返回path所指向的文件或者目錄的最后修改時(shí)間 os.path.getsize(path) 返回path的大小 ''' View Code?注意:os.stat('path/filename')??獲取文件/目錄信息?的結(jié)構(gòu)說明
stat 結(jié)構(gòu):st_mode: inode 保護(hù)模式 st_ino: inode 節(jié)點(diǎn)號。 st_dev: inode 駐留的設(shè)備。 st_nlink: inode 的鏈接數(shù)。 st_uid: 所有者的用戶ID。 st_gid: 所有者的組ID。 st_size: 普通文件以字節(jié)為單位的大小;包含等待某些特殊文件的數(shù)據(jù)。 st_atime: 上次訪問的時(shí)間。 st_mtime: 最后一次修改的時(shí)間。 st_ctime: 由操作系統(tǒng)報(bào)告的"ctime"。在某些系統(tǒng)上(如Unix)是最新的元數(shù)據(jù)更改的時(shí)間,在其它系統(tǒng)上(如Windows)是創(chuàng)建時(shí)間(詳細(xì)信息參見平臺的文檔)。 View Code8.sys 模塊
sys模塊是與python解釋器交互的一個(gè)接口
sys.argv 命令行參數(shù)List,第一個(gè)元素是程序本身路徑 sys.exit(n) 退出程序,正常退出時(shí)exit(0),錯(cuò)誤退出sys.exit(1) sys.version 獲取Python解釋程序的版本信息 sys.path 返回模塊的搜索路徑,初始化時(shí)使用PYTHONPATH環(huán)境變量的值 sys.platform 返回操作系統(tǒng)平臺名稱?
?
轉(zhuǎn)載于:https://www.cnblogs.com/shangchunhong/p/9237556.html
總結(jié)
以上是生活随笔為你收集整理的正则表达式 re sys os random time 模块的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 欲练神功必先自宫,String 自宫后“
- 下一篇: 交罚款!