是这样的,我写了一个爬虫抓取信息存到数据库中,但是这个数据是动态变化的,我需要 24 小时监视。如果发现数据变了,就把这新数据替换掉旧数据。
现在我的代码就只是实现爬取数据并存入到数据库中。
我的更新数据思路就是一直爬,然后把爬到的要插入到数据库的数据(一行)跟数据库目前的某行比较,如果不同,就把旧行删掉,插入新行。
# 思路大概表示
newData = getDataFromWeb()
oldData = getDataFromDB()
if md5(newData) != md5(oldData):
replaceDataInDB(oldData, newData);
难道我要 copy 一份代码再在里面加入更新策略的代码吗? 95%代码量相同,感觉不符合程序员的价值观啊?
各位的爬虫更新策略是怎么样的呢?
1
NullMan 2016-07-31 15:37:29 +08:00
今天天气真不错呀!
|
2
oclock 2016-07-31 16:10:23 +08:00
我没有看懂哪里存在楼主所说的“ copy 一份代码,有 95%的代码相同”
既然是反复爬取,就计划一个 daily cron job :爬取、与数据库对比、 upsert ,一份代码就足够了 |
6
herozzm 2016-08-01 01:07:19 +08:00 via Android
最近一次存内存,爬到的数据和先和内存比对,在和数据库比对,可以减少数据库压力
|
7
superalsrk 2016-08-01 10:34:16 +08:00
做索引。。然后 replace into?
|
8
wuhang89 2016-08-01 22:50:19 +08:00
做个索引啊,两边 hash 比较一下,不一样就认为是更新呗。
|