# -*- coding: utf-8 -*- # !/usr/bin/env python import os, sys,time,datetime import urllib import requests from mongoengine import register_connection, PointField, DynamicDocument, StringField import simplejson as json from django.db.models.fields import DateTimeField PROJECT_ROOT = os.path.join(os.path.abspath(os.path.split(os.path.realpath(__file__))[0] + "/.."), '..') sys.path.insert(0, PROJECT_ROOT) os.environ.setdefault("DJANGO_SETTINGS_MODULE", "configs.testing") from script.base import init_env init_env(interactive = False) from apps.web.core.db import Searchable register_connection(alias = 'spider', name = 'spider', host = '116.62.228.194', port = 27017, username = 'dba', password = 'dayuan@2020..', authentication_source = 'admin') class Goverment(Searchable): province = StringField(default = "") city = StringField(default = "") name = StringField(default = '') lat = StringField(default = '') lng = StringField(default = '') meta = { 'collection': 'Goverment', 'db_alias': 'spider', 'unique_together': {'lat', 'lng'} } class youdianchongDevice(Searchable): meta = { 'collection': 'youdianchong_device', 'db_alias': 'spider', 'unique_together': {'id'} } # 根据二维码编号,获取设备更详细的信息 url = 'http://ydc.youdianchong.com:8087/newCloseCharger?longitude=%s&latitude=%s' govs = Goverment.get_collection().find() for gov in govs: try: print gov['name'] url1 = url % (gov['lng'],gov['lat']) strhtml = requests.get(url1,headers = {'openId':'ozk7Zv4WC5akrk9Lvrm78jggwHk4'}).text result = json.loads(strhtml) if not result.has_key('data'): continue if len(result['data'])== 0: continue print len(result['data']) for dev in result['data']: youdianchongDevice.get_collection().update({'id':dev['id']},{'$set':dev},upsert = True) except Exception,e: continue print('OK')