又来提问了。

2015-06-18 08:51:01 +08:00
 commoccoom
https://gist.github.com/chnt7305/460f73c9ff71f2199d40

https://gist.github.com/chnt7305/694b2cf11dea2c7a444e
3064 次点击
所在节点    Python
14 条回复
commoccoom
2015-06-18 08:52:52 +08:00
为什么 list1 = re.findall(r'<a href="(.*?)" name="readlink" id="[\s\S]+" class="subject_t f12" >(.*?)</a>',html)

html 是整个页面,为什么只抓取到了5个
commoccoom
2015-06-18 08:55:10 +08:00
Septembers
2015-06-18 08:58:38 +08:00
你应该用 requests和BeautifulSoup 来处理这个问题
而不是 urllib和正则 来处理这个问题
josephok
2015-06-18 09:01:41 +08:00
用xpath吧
mhycy
2015-06-18 09:43:33 +08:00
<a href="(.*?)" name="readlink" id="(.*?)" class="subject_t f12" >(.*?)<\/a>
改成这样试试。。
imn1
2015-06-18 11:08:33 +08:00
<a href="(.*?)" name="readlink" id="[^"]+" class="subject_t f12" >(.*?)</a>
imn1
2015-06-18 11:14:06 +08:00
养成习惯,引号内都用 [^"]+ 或 [^']+
或者这样说:左右边界清晰的内容,泛匹配的话,使用排除边界来匹配

能用正则尽量雍正则,bs / xpath都需要一个额外的dom解析过程,大量页面的话资源消耗很严重
commoccoom
2015-06-18 14:18:29 +08:00
@imn1

非常感谢!
Septembers
2015-06-18 14:35:53 +08:00
@imn1 大量文本提取信息格式稳定的话 正则是要好得多 但是前提是熟悉正则(我以前写正则一不注意没写好 就进贪婪匹配 然后就over了 唉

如果在不熟悉正则的情况下处理HTML
还是老老实实的DOM解析比较好
garfeildma
2015-06-18 16:50:17 +08:00
简单的一次性的工作可以用正则来完成,正规做法还是老老实实解析html,原因看这里
http://stackoverflow.com/questions/1732348/regex-match-open-tags-except-xhtml-self-contained-tags
loading
2015-06-18 16:53:56 +08:00
下次标题写明白点…求您了!
Axurez
2015-06-18 17:02:53 +08:00
正则开销会比较大吧,复杂一点的基本不可能实际运行的。。
commoccoom
2015-06-18 18:39:41 +08:00
@loading

不好意思。。。。。我不知道用什么标题合适
fltw
2015-06-21 06:44:50 +08:00
不知道楼主在说什么啊,我这连连接都打不开。。。
正则表达式太。。。。。怎么说,必须要熟练,否则很痛苦的,需要经常修改

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/199428

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX