亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

在python中使用正則表達式查找可嵌套字符串組

系統(tǒng) 2018 0

在網(wǎng)上看到一個小需求,需要用正則表達式來處理。原需求如下:

找出文本中包含”因為……所以”的句子,并以兩個詞為中心對齊輸出前后3個字,中間全輸出,如果“因為”和“所以”中間還存在“因為”“所以”,也要找出來,另算一行,輸出格式為:

行號 前面3個字 *因為* 全部 &所以& 后面3個字(標點符號算一個字)

2 還不是 *因為* 這里好, &所以& 沒有人

實現(xiàn)方法如下:

            
#encoding:utf-8
import os
import re
def getPairStriList(filename):
  pairStrList = []
  textFile = open(filename, 'r')
  pattern = re.compile(u'.{3}\u56e0\u4e3a.*\u6240\u4ee5.{3}') #u'\u56e0\u4e3a和u'\u6240\u4ee5'分別為“因為”和“所以”的utf8碼
  for line in textFile:
    utfLine = line.decode('utf8')
    result = pattern.search(utfLine)
    while result:
      resultStr = result.group()
      pairStrList.append(resultStr)
      result = pattern.search(resultStr,2,len(resultStr)-2)
  #對每個字符串進行格式轉(zhuǎn)換和拼接  
  for i in range(len(pairStrList)):
    pairStrList[i] = pairStrList[i][:3] + pairStrList[i][3:5].replace(u'\u56e0\u4e3a',u' *\u56e0\u4e3a* ',1) + pairStrList[i][5:]
    pairStrList[i] = pairStrList[i][:len(pairStrList[i])-5] + pairStrList[i][len(pairStrList[i])-5:].replace(u'\u6240\u4ee5',u' &\u6240\u4ee5& ',1)
    pairStrList[i] = str(i+1) + ' ' + pairStrList[i]
  return pairStrList
  if __name__ == '__main__':
  pairStrList = getPairStriList('test.txt')
  for str in pairStrList:
    print str
          

PS:下面看下python里使用正則表達式的組嵌套

由于組本身是一個完整的正則表達式,所以可以將組嵌套在其他組中,以構(gòu)建更復(fù)雜的表達式。下面的例子,就是進行組嵌套的例子:

            
#python 3.6 
#蔡軍生  
#http://blog.csdn.net/caimouse/article/details/51749579 
# 
import re 
def test_patterns(text, patterns): 
  """Given source text and a list of patterns, look for 
  matches for each pattern within the text and print 
  them to stdout. 
  """ 
  # Look for each pattern in the text and print the results 
  for pattern, desc in patterns: 
    print('{!r} ({})\n'.format(pattern, desc)) 
    print(' {!r}'.format(text)) 
    for match in re.finditer(pattern, text): 
      s = match.start() 
      e = match.end() 
      prefix = ' ' * (s) 
      print( 
        ' {}{!r}{} '.format(prefix, 
                   text[s:e], 
                   ' ' * (len(text) - e)), 
        end=' ', 
      ) 
      print(match.groups()) 
      if match.groupdict(): 
        print('{}{}'.format( 
          ' ' * (len(text) - s), 
          match.groupdict()), 
        ) 
    print() 
  return 
          

例子:

            
#python 3.6 
#蔡軍生  
#http://blog.csdn.net/caimouse/article/details/51749579 
# 
from re_test_patterns_groups import test_patterns 
test_patterns( 
  'abbaabbba', 
  [(r'a((a*)(b*))', 'a followed by 0-n a and 0-n b')], 
) 
          

結(jié)果輸出如下:

            
'a((a*)(b*))' (a followed by 0-n a and 0-n b)
 'abbaabbba'
 'abb'    ('bb', '', 'bb')
   'aabbb'  ('abbb', 'a', 'bbb')
     'a' ('', '', '')
          

總結(jié)

以上所述是小編給大家介紹的在python中使用正則表達式查找可嵌套字符串組,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 久久综合香蕉 | 最近中文字幕在线 | 中文 | 大学生久久香蕉国产线看观看 | 涩涩视频免费 | 91精品论坛| 米奇777第四久久久99 | 成人a在线| 欧美日韩在线播一区二区三区 | 999在线播放 | 九九亚洲综合精品自拍 | 欧美成人鲁丝片在线观看 | 黄色自拍网站 | 四虎精品免费国产成人 | 国产精品区一区二区三 | 日本吻胸抓胸激烈视频网站 | 91精品国产高清久久久久久io | 成人在色线视频在线观看免费大全 | 国产成人亚洲精品老王 | 激情欧美 | 99精品高清视频一区二区 | 在线aa| 久久久久久久国产视频 | 99热这里只有精品3 99热这里只有精品4 | 四虎国产精品永久在线看 | 亚洲最大在线观看 | 国产一级α片 | 欧美国产一区二区二区 | 99爱网站| 免费视频精品一区二区 | 欧美777精品久久久久网 | 97视频在线播放 | 麻豆一区二区三区四区 | 97香蕉久久夜色精品国产 | 一级毛片视频 | 成人毛片在线观看 | 校园春色男人天堂 | 色婷婷六月桃花综合影院 | 国产中文一区 | 热久久精品 | 免费播放国产一级 | 免费可以直接观看的毛片 |