日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python正则表达式面试_Python面试 Re-正则表达式

發布時間:2023/12/2 python 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python正则表达式面试_Python面试 Re-正则表达式 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1.python正則表達式中匹配(match)和查找(search)的區別

答:正則表達式中match和search的方法比較相似

相同點:都是在一個字符串s中尋找pat子字符串,如果能找到,就返回一個Match對象,如果找不到,就返回None。

不同點:mtach方法是從頭開始匹配,而search方法,可以在s字符串的任一位置查找。

從結果中,我們可以看出,

python中用match和search方法都可以反饋ours中的our字符串,而對于flourish,只有search能返回Match對象,而因為不是在頭部匹配到,所以match方法返回了None。

2.再python中group和groups的區別

答:group和groups是兩個不同的函數。

一般,m.group(N) 返回第N組括號匹配的字符。

而m.group()== m.group(0) ==所有匹配的字符,與括號無關,這個是API規定的。

m.groups() 返回所有括號匹配的字符,以tuple格式(元組格式),不包括

m.group(0),即整個表達式.

m.groups()== (m.group(0), m.group(1),……)

3.python中運用正則去除以下html文件中的標簽,只顯示文本信息。

答:利用python正則表達式re模塊中的sub方法,將標簽替換為空字符串,代碼如下

#-*- cording:utf-8 -*-

importre#去除標簽

s= "

\

小當家

\

python面試題匯總

\"p= r"?\w+>|nbsp;"

print(re.sub(p," ",s))#打印

小當家

python面試題匯總

4.python中用正則表達式提取字符串中所有域名:

答:利用sub方法,將整個字符串替換為只含域名的字符串。代碼如下:

#-*- coding:utf-8 -*-

importre#提取出域名

s2 = """http://www.baidu.com/?id=35

http://youku.com/news_show.asp?id=14

http://taobao.com?id=768

http://toutiao.com/?newsid=377&id=6

http://www.jd.com/newslist.asp?id=415"""p= r"(http://.+?/).+"

print(re.sub(p,lambda x :x.group(1),s2))#打印

http://www.baidu.com/http://youku.com/http://taobao.com?id=768http://toutiao.com/http://www.jd.com/

5.利用python正則表達式,從字符串"hello world luozhixiang"中,提取出所有單詞

答:利用split方法分割空格或者用findall方法尋找到所有的單詞,代碼如下

#-*- coding:utf-8 *-

importre

s= 'hello world china'p= re.split(r"+",s)

res= re.findall(r"\b\w+\b",s)print(p)print(res)#打印

['hello', 'world', 'china']

['hello', 'world', 'china']

6.python正則表達式中“.*”和“.*?”的區別

表達式 .*的意思很好理解,就是單個字符匹配任意次,即貪婪匹配。

表達式 .*? 是滿足條件的情況只匹配一次,即懶惰匹配

演示代碼和演示結果如下:

#-*- coding :utf-8 -*-

importre

p_1= re.compile(".*([1-9]\\d*|[一兩二三四五六七八九十]{1,3})(百|千|)米.*")

p_2= re.compile(".*?([1-9]\\d*|[一兩二三四五六七八九十]{1,3})(百|千|)米.*")

string= "附近5100米"all_data_1=p_1.findall(string)

all_data_2=p_2.findall(string)for data inall_data_1:print(data)for data inall_data_2:print(data)#打印

('100', '')

('5100', '')

7.利用python語言,使用正則將字符串"羅志祥202004月真的很倒霉,替蔣凡當了3695489點傷害"中,連續5個以上數字替換成*

#-*- coding:utf-8-*-

importre

s="羅志祥202004月真的很倒霉,替蔣凡當了3695489點傷害"res= re.compile(r'\d{5}')

ret= res.sub('*',s)print(ret)#打印

羅志祥*4月真的很倒霉,替蔣凡當了*89點傷害

總結

以上是生活随笔為你收集整理的python正则表达式面试_Python面试 Re-正则表达式的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。