python 字符串匹配問題
問題描述
想匹配html = <p class='back fl'><a href='javascript:void(0);' onclick='_gaq.push([’_trackEvent’,’function’, ’onclick’, ’blog_articles_shangyipian’]);location.href=’/u012582664/article/details/56845037’;'><span><i class='fa fa-arrow-left'></i></span><em>安裝最新版python</em></a></p><p class='forward fr'><a href='javascript:void(0);' onclick='_gaq.push([’_trackEvent’,’function’, ’onclick’, ’blog_articles_xiayipian’]);location.href=’/u012582664/article/details/59120585’;'><em>各種數據庫的注釋</em><span><i class='fa fa-arrow-right'></i></span></a></p>中的‘56845037’和‘59120585’,嘗試用正則:
pattern_l = r’’’<a href='javascript:void(0);' onclick='_gaq.push([’_trackEvent’,’function’, ’onclick’, ’blog_articles_shangyipian’]);location.href=’(.+?)’;'>’’’re.findall(pattern_l,html)
結果不成功。返回為空,有用:
soup = BeautifulSoup(html, 'lxml')print(soup.find_all(onclick='_gaq.push([’_trackEvent’,’function’, ’onclick’, ’blog_articles_shangyipian’]);location.href=’/u012582664/article/details/(.+?)’;'))
還是返回空,請教各位怎么寫才行,是哪里出了問題
問題解答
回答1:前面那一大堆東西其實用不著匹配。
匹配這些就夠了:
re.findall(r'location.href=’/u012582664/article/details/(d+)',html)回答2:
括號轉義下試試?小括號和中括號在正則里有特殊意義
相關文章:
1. node.js - node中MYSQL的異步問題2. mysql儲存json錯誤3. 我何時應該在Java中使用JFrame.add(component)和JFrame.getContentPane()。add(component)4. javascript - ie11以下單擊打開不了file,雙擊可以。求解?5. 輸入地址報以下截圖錯誤,怎么辦?6. mysql分庫分表量級疑問7. 為啥獲取不到呀?8. php怎么用isMobile()函數識別pc端移動端自動跳轉9. vim里的高亮javascript的javascript.vim 已經放到syntax里了,但是不行。10. html5 - 在Mac里使用vscode,卻無法使用已下載的擴展……
