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. css - input中transition 設置background-color過渡,chrome瀏覽器頁面初始化渲染會有過度效果2. 在mac下出現了兩個docker環境3. 網絡傳輸協議 - 以下三種下載方式有什么不同?如何用python模擬下載器下載?4. android - As ddms報錯5. javascript - node中為中間層如何解決跨域問題6. 編程小白 問關于python當中類的方法的參數問題7. Python pyinstaller 打包后在其他電腦運行失敗8. linux - python 安裝 Anaconda 環境變量問題請教9. javascript - webpack打包問題10. angular.js - angular ui bootstrap 中文顯示問題
