一个python小爬虫

iPhone6刚出的时候,移动官网有个每满十万送一台iPhone,当时用这个小爬虫自动爬,快到十万的时候打开浏览器(这个版本好像没加这个功能),哈哈,现在用不了,这篇从我扣扣空间(那时我还年少,只知道QQ)转过来的,扣扣空间显示代码太糟糕了,迁过来,里面有句不错设置本地编码,转码使用urllib2和cookeie,json等要素的小爬虫,还是有点参考价值。

# -*- coding: utf-8 -*-
import sys
import urllib2
import cookielib
import json
import time

url = "http://service.js.10086.cn/act_js/activity_web/1319/home.html"
getNumUrl = "http://service.js.10086.cn/cmp_service/actionDispatcher.do"
# 添加 cookie 到 urllib2
cj = cookielib.LWPCookieJar()
cookie_support = urllib2.HTTPCookieProcessor(cj)
opener = urllib2.build_opener(cookie_support, urllib2.HTTPHandler)
urllib2.install_opener(opener)

# 伪装成浏览器的头, 移动真蛋疼检测浏览器的
headers = {'User-Agent': 'Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/39.0.2171.95 Safari/537.36',
           'Origin': 'http://service.js.10086.cn', 'Referer': 'http://service.js.10086.cn/act_js/activity_web/1319/index.html?WT.mc_ev=1412RRHB_JL'}
req = urllib2.Request(url, headers=headers)
urllib2.urlopen(req)
type = sys.getfilesystemencoding()     # 设置本地编码
# 打印第一访问的网页
#content = urllib2.urlopen(req).read()
# print content.decode("UTF-8").encode(type)  # convert encode format
# 请求参数
postData = """jsonParam=%5B%7B%22activityCode%22%3A%221319%22%2C%22dynamicURI%22%3A%22doubleAct%22%2C%22dynamicParameter%22%3A%7B%22method%22%3A%22queryUserLoginInfo%22%2C%22actStageCode%22%3A%221319%22%7D%2C%22dynamicDataNodeName%22%3A%22API_queryUserLoginInfo_doubleAct%22%2C%22dynamicPriority%22%3A1%7D%5D
"""
request = urllib2.Request(getNumUrl, postData, headers)
response = urllib2.urlopen(request)
text = response.read()
nextNum = int(json.loads(text)[
              "API_queryUserLoginInfo_doubleAct"]["resultObj"]["nextNum"])
max = 0
print "下一轮上限", nextNum, "万, 计数中最后一百进行倒计时"
while True:
    response = urllib2.urlopen(request)
    text = response.read()
    # print text.decode("UTF-8").encode(type)
    num = int(json.loads(text)[
            "API_queryUserLoginInfo_doubleAct"]["resultObj"]["fnum"])
    if num > max:
        max = num
        print max
    if num > nextNum * 10000:  # 大于某个上限后停止
        break
    elif num > nextNum * 10000 - 100:  # 最后一百个加速
        time.sleep(0.1)
    elif num > nextNum * 10000 - 500:
        time.sleep(0.5)
    elif num > nextNum * 10000 - 1000:
        time.sleep(1)
    else:
        time.sleep(3)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值