roll_wangqiu.py 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377
  1. # -*- coding: utf-8 -*-
  2. import datetime
  3. import json
  4. import jsonpath
  5. import scrapy
  6. from scrapy.http import Request
  7. # from ..items import Lanqiu
  8. from ..items import Roll_Wangqiu
  9. def rangqiu_daxiao(inner):
  10. concede = [inner[i] for i in range(len(inner)) if i % 2 == 1]
  11. # 主队让球条件赔率
  12. concedehome = [concede[i] for i in range(len(concede)) if i % 2 == 0]
  13. # 客队让球条件赔率
  14. concedeguest = [concede[i] for i in range(len(concede)) if i % 2 == 1]
  15. # 主队让球条件
  16. concede_home_rule = [concedehome[i] for i in range(len(concedehome)) if i % 2 == 0]
  17. # 主队让球赔率
  18. concede_home = [concedehome[i] for i in range(len(concedehome)) if i % 2 == 1]
  19. # 客队让球条件
  20. concede_guest_rule = [concedeguest[i] for i in range(len(concedeguest)) if i % 2 == 0]
  21. # 客队让球赔率
  22. concede_guest = [concedeguest[i] for i in range(len(concedeguest)) if i % 2 == 1]
  23. return concede_home_rule, concede_home, concede_guest_rule, concede_guest
  24. def danshaung_fun(inner):
  25. odd_even = [inner[i] for i in range(len(inner)) if i % 2 == 1]
  26. # 全场 总分单
  27. odd_even_odd = [odd_even[i] for i in range(len(odd_even)) if i % 2 == 0]
  28. # 全场 总分双
  29. odd_even_even = [odd_even[i] for i in range(len(odd_even)) if i % 2 == 1]
  30. return odd_even_odd, odd_even_even
  31. class WangqiuSpider(scrapy.Spider):
  32. name = "roll_wangqiu"
  33. to_day = datetime.datetime.now()
  34. allowed_domains = ['hg3535z.com']
  35. start_urls = ['https://hg3535z.com/odds2/d/getodds?sid=3&pt=4&ubt=am&pn=0&sb=2&dc=null&pid=0'] # 滚球菜单 网球滚球列url
  36. custom_settings = {
  37. "ITEM_PIPELINES": {
  38. "hg3535.pipelines.Roll_Wangqiupipeline": 350,
  39. },
  40. 'LOG_LEVEL': 'DEBUG',
  41. 'LOG_FILE': "../hg3535/log/roll_wangqiu_{}_{}_{}.log".format(to_day.year, to_day.month, to_day.day)
  42. }
  43. # start_urls = ['http://hg3535z.com/odds2/d/getodds?sid=2&pt=3&ubt=am&pn=0&sb=2&dc=null&pid=0']
  44. # http: // hg3535z.com / odds2 / d / getamodds?eid = 3098030 & iip = false & ubt = am & isp = false
  45. # http://hg3535z.com/odds2/d/getodds?sid=2&pt=2&ubt=am&pn=0&sb=2&dc=null&pid=0
  46. def parse(self, response):
  47. datas = json.loads(response.text)
  48. # item = Today_all()
  49. ids = jsonpath.jsonpath(datas, '$..i-ot[0]..egs..es..i[16]') # ids新列表
  50. print(ids)
  51. if ids:
  52. ids = set(ids)
  53. for i in ids:
  54. urls = 'https://hg3535z.com/odds2/d/getamodds?eid={}&iip=true&ubt=am&isp=false'.format(i)
  55. print(urls)
  56. yield Request(url=urls, callback=self.parse_other)
  57. def parse_other(self,response):
  58. new_datas = json.loads(response.text).get('eg', "")
  59. try:
  60. pt = response.meta['pt']
  61. except:
  62. pt = 0
  63. item = Roll_Wangqiu()
  64. if new_datas:
  65. # 联赛id
  66. league_id = new_datas.get("c", "").get("k", "")
  67. # 联赛名
  68. league_name = new_datas.get("c", "").get("n", "")
  69. new_data = new_datas.get("es", "")
  70. result = new_data[0]
  71. # 比赛id
  72. game_id = str(result['k'])
  73. # 球队1
  74. team_home = result['i'][0]
  75. # 球队2
  76. team_guest = result['i'][1]
  77. # 数量(97>)
  78. number = result['i'][2]
  79. # 比赛状态
  80. zhuangtai = result['i'][3]
  81. # 日期
  82. data_game = result['i'][4]
  83. # 开赛时间 滚球实际只有一个进行时间
  84. # time_game = result['i'][5]
  85. try:
  86. time_game = result['sb']['ct']
  87. except:
  88. time_game = '01:00'
  89. # time_game = '00:00:00'
  90. # time_game = result.get('sb',"").get('ct',"")
  91. # 队1分数
  92. score_home1 = result['i'][10]
  93. # 队2分数
  94. score_guest1 = result['i'][11]
  95. # 第几节
  96. jijie = result['i'][12]
  97. # 球队得分
  98. qiudui = result['pci'].get('ctn', "")
  99. # ----------------------------------------让球分割线---------------------------------------------------------------------------
  100. concedes_dict = {}
  101. concedes_dict_rule = {}
  102. try:
  103. # 滚球让盘
  104. concedes = result['o']["ah"]["v"]
  105. concedes_dict_rule['dishes_home'] = concedes[1]
  106. concedes_dict['dishes_home'] = concedes[5]
  107. concedes_dict_rule['dishes_guest'] = concedes[3]
  108. concedes_dict['dishes_guest'] = concedes[7]
  109. except:
  110. concedes_dict_rule['dishes_home'] = ""
  111. concedes_dict['dishes_home'] = ""
  112. concedes_dict_rule['dishes_guest'] = ""
  113. concedes_dict['dishes_guest'] = ""
  114. # print(concedes_dict)
  115. # ----------------------------------------第一节让球分割线---------------------------------------------------------------------------
  116. #第一节让球
  117. try:
  118. # 第一节让球
  119. one_concedes = result['o']["ahs1"]["v"]
  120. one_concede_home_rule,one_concede_home,one_concede_guest_rule,one_concede_guest= rangqiu_daxiao(inner=one_concedes)
  121. concedes_dict_rule['one_concede_home'] = ''.join(one_concede_home_rule)
  122. concedes_dict['one_concede_home'] = ''.join(one_concede_home)
  123. concedes_dict_rule['one_concede_guest'] = ''.join(one_concede_guest_rule)
  124. concedes_dict['one_concede_guest'] = ''.join(one_concede_guest)
  125. except:
  126. one_concede_guest = ""
  127. one_concede_guest_rule = ""
  128. one_concede_home = ""
  129. one_concede_home_rule = ""
  130. concedes_dict['one_concede_home_rule'] = one_concede_home_rule
  131. concedes_dict['one_concede_home'] = one_concede_home
  132. concedes_dict['one_concede_guest_rule'] = one_concede_guest_rule
  133. concedes_dict['one_concede_guest'] = one_concede_guest
  134. # ----------------------------------------第二节让球分割线---------------------------------------------------------------------------
  135. #第二节让球
  136. # 第二节让球
  137. try:
  138. two_concedes = result['o']["ahs2"]["v"]
  139. two_concede_home_rule,two_concede_home,two_concede_guest_rule,two_concede_guest = rangqiu_daxiao(inner=two_concedes)
  140. concedes_dict_rule['two_concede_home'] = ''.join(two_concede_home_rule)
  141. concedes_dict['two_concede_home'] = ''.join(two_concede_home)
  142. concedes_dict_rule['two_concede_guest'] = ''.join(two_concede_guest_rule)
  143. concedes_dict['two_concede_guest'] = ''.join(two_concede_guest)
  144. except:
  145. two_concede_guest = ""
  146. two_concede_guest_rule = ""
  147. two_concede_home = ""
  148. two_concede_home_rule = ""
  149. concedes_dict_rule['two_concede_home'] = two_concede_home_rule
  150. concedes_dict['two_concede_home'] = two_concede_home
  151. concedes_dict_rule['two_concede_guest'] = two_concede_guest_rule
  152. concedes_dict['two_concede_guest'] = two_concede_guest
  153. # ---------------------------------------------------冠军 滚球是独赢----------------------------------------------------------------
  154. kemps_dict = {}
  155. try:
  156. kemps = result['o']["ml"]["v"]
  157. kemps_dict['kemp_home'] = kemps[1]
  158. kemps_dict['kemp_guest'] = kemps[3]
  159. except:
  160. kemps_dict['kemp_home'] = ""
  161. kemps_dict['kemp_guest'] = ""
  162. # 第一盘 冠军 第一盘独赢 滚球是独赢
  163. try:
  164. kemps = result['o']["mls1"]["v"]
  165. kemps_dict['one_kemp_home'] = kemps[1]
  166. kemps_dict['one_kemp_guest'] = kemps[3]
  167. except:
  168. kemps_dict['one_kemp_home'] = ""
  169. kemps_dict['one_kemp_guest'] = ""
  170. try: # 第二盘 独赢
  171. kemps = result['o']["mls2"]["v"]
  172. kemps_dict['two_kemp_home'] = kemps[1]
  173. kemps_dict['two_kemp_guest'] = kemps[3]
  174. except:
  175. kemps_dict['two_kemp_home'] = ""
  176. kemps_dict["two_kemp_guest"] = ""
  177. # ---------------------------------------------------让局---------------------------------------------------------------
  178. bureaus_dict = {}
  179. bureaus_dict_rule = {}
  180. try:
  181. bureaus = result['o']["ahfts"]["v"]
  182. bureaus_dict_rule['concede_home'] = bureaus[1]# 添加前缀
  183. bureaus_dict['concede_home'] = bureaus[5]#
  184. bureaus_dict_rule['concede_guest'] = bureaus[3]#
  185. bureaus_dict['concede_guest'] = bureaus[7]##
  186. except:
  187. bureaus_dict_rule['concede_home'] = ""
  188. bureaus_dict['concede_home'] = ""
  189. bureaus_dict_rule['concede_guest'] = ""
  190. bureaus_dict['concede_guest'] = ""
  191. # -----------------------------------------------------总局数 第一盘:大/小------------------------------------------------------
  192. total_number_dict = {}
  193. total_number_dict_rule = {}
  194. try: #总局数 滚球大小
  195. total_numbers = result['o']["oufts"]["v"]
  196. total_number_dict_rule['total_number_big'] = total_numbers[1] #添加前缀wp
  197. total_number_dict['total_number_big'] = total_numbers[5]
  198. total_number_dict_rule['total_number_small'] = total_numbers[3]
  199. total_number_dict['total_number_small'] = total_numbers[7]
  200. except:
  201. total_number_dict_rule['total_number_big'] = ""
  202. total_number_dict['total_number_big'] = ""
  203. total_number_dict_rule['total_number_small'] = ""
  204. total_number_dict['total_number_small'] = ""
  205. # 第一节盘
  206. try:
  207. one_total_sizes = result['o']["ous1"]["v"]
  208. one_total_sizes_big_rule,one_total_sizes_big,one_total_sizes_small_rule,one_total_sizes_small = rangqiu_daxiao(inner=one_total_sizes)
  209. total_number_dict_rule["one_total_sizes_big"] = ''.join(one_total_sizes_big_rule)
  210. total_number_dict["one_total_sizes_big"] = ''.join(one_total_sizes_big)
  211. total_number_dict_rule["one_total_sizes_small"] = ''.join(one_total_sizes_small_rule)
  212. total_number_dict["one_total_sizes_small"] = ''.join(one_total_sizes_small)
  213. except:
  214. one_total_sizes_big_rule = ""
  215. one_total_sizes_big = ""
  216. one_total_sizes_small_rule = ""
  217. one_total_sizes_small = ""
  218. total_number_dict_rule["one_total_sizes_big"] = ''.join(one_total_sizes_big_rule)
  219. total_number_dict["one_total_sizes_big"] = ''.join(one_total_sizes_big)
  220. total_number_dict_rule["one_total_sizes_small"] = ''.join(one_total_sizes_small_rule)
  221. total_number_dict["one_total_sizes_small"] = ''.join(one_total_sizes_small)
  222. # 第二节盘
  223. try:
  224. two_total_sizes = result['o']["ous2"]["v"]
  225. two_total_sizes_big_rule,two_total_sizes_big,two_total_sizes_small_rule,two_total_sizes_small = rangqiu_daxiao(inner=two_total_sizes)
  226. total_number_dict_rule["two_total_sizes_big"] = two_total_sizes_big_rule
  227. total_number_dict["two_total_sizes_big"] = "".join(two_total_sizes_big)
  228. total_number_dict_rule["two_total_sizes_small"] = "".join(two_total_sizes_small_rule)
  229. total_number_dict["two_total_sizes_small"] = "".join(two_total_sizes_small)
  230. except:
  231. two_total_sizes_big_rule = ""
  232. two_total_sizes_big = ""
  233. two_total_sizes_small_rule = ""
  234. two_total_sizes_small = ""
  235. total_number_dict_rule["two_total_sizes_big"] = two_total_sizes_big_rule
  236. total_number_dict["two_total_sizes_big"] = ''.join(two_total_sizes_big)
  237. total_number_dict_rule["two_total_sizes_small"] = ''.join(two_total_sizes_small_rule)
  238. total_number_dict["two_total_sizes_small"] = ''.join(two_total_sizes_small)
  239. # 第三节盘
  240. try:
  241. three_total_sizes = result['o']["ous3"]["v"]
  242. three_total_sizes_big_rule,three_total_sizes_big,three_total_sizes_small_rule,three_total_sizes_small = rangqiu_daxiao(inner=three_total_sizes)
  243. total_number_dict_rule["three_total_sizes_big"] = ''.join(three_total_sizes_big_rule)
  244. total_number_dict["three_total_sizes_big"] = three_total_sizes_big
  245. total_number_dict_rule["three_total_sizes_small"] = ''.join(three_total_sizes_small_rule)
  246. total_number_dict["three_total_sizes_small"] = ''.join(three_total_sizes_small)
  247. except:
  248. three_total_sizes_big_rule = ""
  249. three_total_sizes_big = ""
  250. three_total_sizes_small_rule = ""
  251. three_total_sizes_small = ""
  252. total_number_dict_rule["three_total_sizes_big"] = ''.join(three_total_sizes_big_rule)
  253. total_number_dict["three_total_sizes_big"] = three_total_sizes_big
  254. total_number_dict_rule["three_total_sizes_small"] = ''.join(three_total_sizes_small_rule)
  255. total_number_dict["three_total_sizes_small"] = three_total_sizes_small
  256. # ------------------------------------------------------总局数:单/双-----------------------------------------------------
  257. odd_evens_dict = {}
  258. odd_evens_dict_rule = {}
  259. try:
  260. odd_evens = result['o']["oefts"]["v"]
  261. # 上半场 主队让球条件
  262. odd_evens_dict['two_sides_single'] = odd_evens[1] # 之前是odd_even_odd
  263. odd_evens_dict_rule['two_sides_single'] = "单"
  264. odd_evens_dict['two_sides_double'] = odd_evens[3]
  265. odd_evens_dict_rule['two_sides_double'] = "双"
  266. except:
  267. odd_evens_dict['two_sides_single'] = ""
  268. odd_evens_dict['two_sides_single'] = ""
  269. odd_evens_dict_rule['two_sides_double'] = ""
  270. odd_evens_dict_rule['two_sides_double'] = ""
  271. # 联赛id
  272. item['league_id'] = league_id
  273. # 联赛名
  274. item['league_name'] = league_name
  275. # 比赛id
  276. item['game_id'] = game_id
  277. # 球队1
  278. item['team_home'] = team_home
  279. # 球队2
  280. item['team_guest'] = team_guest
  281. # 数量(97>)
  282. item['number'] = number
  283. # 比赛状态
  284. item['zhuangtai'] = zhuangtai
  285. # 日期
  286. item['data_game'] = data_game
  287. # 开赛时间
  288. item['time_game'] = time_game
  289. # 队1分数
  290. item['score_home'] = score_home1
  291. # 队2分数
  292. item['score_guest'] = score_guest1
  293. # 第几节
  294. item['jijie'] = jijie
  295. item['pt'] = pt
  296. # 球队得分
  297. item['qiudui'] = qiudui
  298. # 让盘
  299. item['concedes_dict'] = concedes_dict
  300. item['concedes_dict_rule'] = concedes_dict_rule
  301. # 冠军
  302. item['kemps_dict'] = kemps_dict
  303. # 让局
  304. item['bureaus_dict'] = bureaus_dict
  305. item['bureaus_dict_rule'] = bureaus_dict_rule
  306. # 总局数大小
  307. item['total_number_dict'] = total_number_dict
  308. item['total_number_dict_rule'] = total_number_dict_rule
  309. # 总局数单双
  310. item['odd_evens_dict'] = odd_evens_dict
  311. item['odd_evens_dict_rule'] = odd_evens_dict_rule
  312. yield item