pianyichong.py 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. # -*- coding: utf-8 -*-
  2. # !/usr/bin/env python
  3. import os, sys,time,datetime
  4. import urllib
  5. import requests
  6. from mongoengine import register_connection, PointField, DynamicDocument, StringField
  7. import simplejson as json
  8. from django.db.models.fields import DateTimeField
  9. PROJECT_ROOT = os.path.join(os.path.abspath(os.path.split(os.path.realpath(__file__))[0] + "/.."), '..')
  10. sys.path.insert(0, PROJECT_ROOT)
  11. os.environ.setdefault("DJANGO_SETTINGS_MODULE", "configs.testing")
  12. from script.base import init_env
  13. init_env(interactive = False)
  14. from apps.web.core.db import Searchable
  15. register_connection(alias = 'spider',
  16. name = 'spider',
  17. host = '211.159.224.10',
  18. port = 27119,
  19. username = 'service',
  20. password = 'oOzjoQcO5DyyiN97AY0NpzJ6vztjNpx5',
  21. authentication_source = 'admin')
  22. class Goverment(Searchable):
  23. province = StringField(default = "")
  24. city = StringField(default = "")
  25. name = StringField(default = '')
  26. lat = StringField(default = '')
  27. lng = StringField(default = '')
  28. meta = {
  29. 'collection': 'Goverment',
  30. 'db_alias': 'spider',
  31. 'unique_together': {'lat', 'lng'}
  32. }
  33. class pianyichongDevice(Searchable):
  34. meta = {
  35. 'collection': 'pianyichong_device',
  36. 'db_alias': 'spider',
  37. 'unique_together': {'id'}
  38. }
  39. # 根据二维码编号,获取设备更详细的信息
  40. url1 = 'http://www.bianyichong.cn/prod/prodInstlPos/queryGeo'
  41. ii = 43570
  42. govs = Goverment.get_collection().find()
  43. devIdMap = {}
  44. for dev in pianyichongDevice.get_collection().find({}):
  45. devIdMap[dev['id']] = 1
  46. for gov in govs[ii:]:
  47. try:
  48. ii += 1
  49. print ii
  50. if not (u'政府' in gov['name'] or u'局' in gov['name']):
  51. continue
  52. data = {'lng':gov['lng'],'lat':gov['lat'],'bizNo':'B100000','distance':3000}
  53. strhtml = requests.post(url1,data=data).text
  54. result = json.loads(strhtml)
  55. if not result.has_key('model'):
  56. continue
  57. if not result['model'].has_key('prodInstlPosList') or len(result['model']['prodInstlPosList']) == 0:
  58. continue
  59. for dev in result['model']['prodInstlPosList']:
  60. if dev['id'] in devIdMap:
  61. continue
  62. pianyichongDevice.get_collection().update({'id':dev['id']},{'$set':dev},upsert = True)
  63. devIdMap[dev['id']] = 1
  64. print 'new one!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!'
  65. except Exception,e:
  66. print 'eeeeeeeeeeeeeeeeeeeeeee',e
  67. continue
  68. print('OK')