new_1777.py 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. #import redis
  2. import time
  3. import traceback
  4. #import json
  5. from selenium import webdriver
  6. from selenium.webdriver.common.desired_capabilities import DesiredCapabilities
  7. import time
  8. import os
  9. import urllib.parse
  10. from selenium.webdriver.support.ui import WebDriverWait
  11. from selenium.webdriver.common.by import By
  12. from selenium.webdriver.support import expected_conditions as EC
  13. import codecs
  14. import random
  15. import requests
  16. import time
  17. import sys
  18. import docker
  19. import codecs
  20. import random
  21. import os
  22. import time
  23. driver=None
  24. headers = {
  25. "Authorization": "Bearer " + "t35vhZtWNgvDNWHc3DJh0OKll3mcB9GvC8K2EAkBug2",
  26. "Content-Type": "application/x-www-form-urlencoded"
  27. }
  28. def send_msg(kw):
  29. params = {"message": "處理關鍵字: "+kw}
  30. r = requests.post("https://notify-api.line.me/api/notify",headers=headers, params=params)
  31. def empty_query(q):
  32. global driver
  33. googleurl='https://www.google.com/search?q='+urllib.parse.quote(q)
  34. driver.get(googleurl)
  35. time.sleep(3)
  36. def process_query(qs):
  37. q=qs[0]
  38. domain=qs[2]
  39. cnt=qs[1]
  40. global driver
  41. googleurl='https://www.google.com/search?q='+urllib.parse.quote(q)
  42. driver.get(googleurl)
  43. time.sleep(3)
  44. if cnt > 0:
  45. for i in range(cnt):
  46. elmt=driver.find_element_by_xpath("//a[@id='pnnext']")
  47. webdriver.ActionChains(driver).move_to_element(elmt).perform()
  48. webdriver.ActionChains(driver).move_to_element(elmt).click().perform()
  49. time.sleep(3)
  50. elmts=driver.find_elements_by_xpath("//div[@class='g']//div[@class='yuRUbf']//a")
  51. idx=1
  52. ranking=-1
  53. for elmt in elmts:
  54. href=elmt.get_attribute('href')
  55. txt=elmt.text
  56. if len(txt)>10:
  57. # if 'hhh.com.tw' in href:
  58. # if 'hhh.com.tw' in href:
  59. # if 'ai.choozmo.com' in href:
  60. if domain in href:
  61. # if 'searchome.net' in href:
  62. webdriver.ActionChains(driver).move_to_element(elmt).perform()
  63. webdriver.ActionChains(driver).move_to_element(elmt).click().perform()
  64. break
  65. def re_get_webdriver():
  66. global portnum
  67. global driver
  68. result=[]
  69. # client = docker.from_env()
  70. # ls=client.containers.list()
  71. # print(ls)
  72. # for l in ls:
  73. # if 'p17777' in l.name:
  74. # ls[0].restart()
  75. # time.sleep(4)
  76. if driver is not None:
  77. print('closing....')
  78. driver.quit()
  79. # options = webdriver.EdgeOptions()
  80. try:
  81. driver = webdriver.Remote(
  82. command_executor='http://127.0.0.1:'+str(portnum)+'/wd/hub')
  83. driver.set_window_size(1400,1000)
  84. return
  85. except:
  86. import traceback
  87. traceback.print_exc()
  88. driver=None
  89. return None
  90. driver=None
  91. def run_once(url):
  92. global driver
  93. i=random.randint(0,15)
  94. if i==0 or driver is None:
  95. # if True:
  96. re_get_webdriver()
  97. time.sleep(3)
  98. if driver is None:
  99. return
  100. try:
  101. driver.execute_script('window.open("'+url+'","_blank");')
  102. driver.execute_script("window.scrollTo(0, window.scrollY + 400)")
  103. time.sleep(0.2)
  104. except:
  105. print('exception')
  106. portnum=int(sys.argv[1])
  107. fpath=__file__
  108. elmts=fpath.split('\\')
  109. fpath=fpath.replace(elmts[-1],'urls.csv')
  110. os.system('docker restart p'+str(portnum))
  111. #client = docker.from_env()
  112. #ls=client.containers.list()
  113. #print(ls)
  114. #for l in ls:
  115. # if 'p17777' in l.name:
  116. # ls[0].restart()
  117. #time.sleep(4)
  118. # fpath=fpath.replace('hhh_click_selenium.py','cases.csv')
  119. print(fpath)
  120. lst=[]
  121. fr=codecs.open(fpath,'r','utf-8')
  122. lines=fr.readlines()
  123. for l in lines:
  124. elmts=l.split(',')
  125. lst.append('https://www.hhh.com.tw'+elmts[0])
  126. fr.close()
  127. #lst=['https://www.hhh.com.tw/columns/detail/3427/index.php']
  128. #for i in range(20):
  129. while True:
  130. l=random.choice(lst)
  131. print(l)
  132. # driver.get(l)
  133. run_once(l)
  134. # time.sleep(2)