时间:2021-07-01 10:21:17 帮助过:354人阅读
- <code class="language-text">//span[@class="pro-title"]/text()
- </code>
没人用BeautifulSoup?
(?<=>).*?(?=<)
如果实际情况中有许多不同的“<>”对,就请自行填充前后向断言的内容
你应该看看汉字编码,网页的编码很可能是GBK,然而python是用的utf8,所以绝对匹配不了
- <code class="language-text">---------------代码区----------------
- # coding:utf-8
- import re
- x='<span class="pro-title">Apple iPhone 5s (A1530) 16GB 金色 移动联通4G手机</span> <span class="pro-price">'
- xre=r'(<span class="pro-title">)(.+)(</span> <span class="pro-price">)'
- z=re.search(xre,x).group(2)
- print z
- ----------</span></span></code>
输出区-----------------------
C:\Python27\python.exe D:/PycharmProjects/爬虫/test.py
Apple iPhone 5s (A1530) 16GB 金色 移动联通4G手机
进程已结束,退出代码0
.+ /sSU
一般情况下可以这样匹配中文,如图:- <code class="language-python3"><span class="kn">import</span> <span class="nn">re</span>
- <span class="kn">import</span> <span class="nn">requests</span> <span class="k">as</span> <span class="nn">req</span>
- <span class="kn">from</span> <span class="nn">bs4</span> <span class="k">import</span> <span class="n">BeautifulSoup</span>
- <span class="n">url</span> <span class="o">=</span> <span class="s">'xxx'</span>
- <span class="n">html</span> <span class="o">=</span> <span class="n">req</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="n">url</span><span class="p">)</span><span class="o">.</span><span class="n">text</span>
- <span class="n">bs</span> <span class="o">=</span> <span class="n">BeautifulSoup</span><span class="p">(</span><span class="n">html</span><span class="p">)</span>
- <span class="n">span</span> <span class="o">=</span> <span class="n">bs</span><span class="o">.</span><span class="n">find_all</span><span class="p">(</span><span class="s">'span'</span><span class="p">,</span> <span class="s">'pro-title'</span><span class="p">)</span>
- <span class="sd">'''</span>
- <span class="sd">span = re.findall('<span\sclass="pro-title">[^<]+</span\sclass="pro-title"></span>', html)
- <span class="sd">s = span[0]</span>
- <span class="sd">m = re.findall('[\u4e00-\u9fa5]+', s)</span>
- <span class="sd">'''</span>
- <span class="n">s</span> <span class="o">=</span> <span class="nb">str</span><span class="p">(</span><span class="n">span</span><span class="p">)</span>
- <span class="n">m</span> <span class="o">=</span> <span class="n">re</span><span class="o">.</span><span class="n">findall</span><span class="p">(</span><span class="s">'[</span><span class="se">\u4e00</span><span class="s">-</span><span class="se">\u9fa5</span><span class="s">]+'</span><span class="p">,</span> <span class="n">s</span><span class="p">)</span>
- <span class="nb">print</span><span class="p">(</span><span class="n">m</span><span class="p">)</span>
- </code>
pyquery 会用jquery的话你会爱上它的
换php用 phpQuery
CSS Selector