我预计的调用示例
from logincraw import BaseCraw, session
app = BaseCraw('baiducraw')
@app.login # 系统登陆逻辑,返回 session
def login():
session.get('https://www.baidu.com')
return session # 必须 return session
@app.whether_login # 验证是否登陆成功的方法
def whether_login(session):
r = session.get('https://www.baidu.com') # 请求系统的某个页面,用于检测是否登陆
if r is 'logined':
return True
else:
return False
@app.check_login(thread = 2) # 参数 thread 启动的线程数。与 app.run()搭配
def start_craw(): # 实际爬虫的逻辑
print('i am running')
return save_to_db()
if __name__ == '__main__':
app.run() # 调用多线程方法
# or
# start_craw() # 调用本身的方法
写了个初版的 demo
https://github.com/aaronhua123/logincraw
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.