问卷自动化selenium|滑块验证|速刷答卷|随机选项|代理池

帮朋友做问卷,需要大量数据堆砌,但又很急。几天时间很紧张担心找不到人来填写答卷。于是,写了个selenium脚本帮一把,记录一下。

selenium伪装

#去除webdriver特征
chrome_options.add_argument("--disable-blink-features=AutomationControlled")
chrome_options.add_argument("--proxy-server=" + '代理池')
# 防止windows识别,添加期权
chrome_options.add_experimental_option('excludeSwitches', ['enable-automation'])
chrome_options.add_argument('user-agent=Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/98.0.4758.82 Safar')
chrome_options.add_argument("--headless")
self.driver = Chrome(options=chrome_options)

代理池可以自行从网上抓取,也可以自行购买相关服务(西索)

1、各个代理ip免费网站抓取:

通过正常的request库,ThreadPool或者scrapy分布式抓取到本地数据库,可以设置定时抓取多个网站,在数据库系统里设置相关的定时任务筛选出合适的代理ip。给个思路

if 你有服务器:把抓取ip的任务放在服务器上,存也存在服务器里,省心省力。

else windows设置定时任务,数据库系统里写个批处理脚本筛掉重复的ip和无效的ip,可用talnet进行测试。

 当然很多网上代理ip多数不稳定且失效时间快,若有闲钱,或者不在意注册用户的小伙伴们可以去各大代理ip官网注册,网搜代理ip就可以看到度娘的各类置顶广告,找那种注册就有免费ip额度的就可以

2、购买相关服务

上面也说到了,各个代理ip服务的服务商,好处就是不费事不费力

智能点击验证

try:
    self.driver.implicitly_wait(1)
    self.driver.find_element_by_xpath('//*[@id="alert_box"]/div[2]/div[2]/button').click()
    #//*[@id="rectTop"]
    self.driver.find_element_by_xpath('//*[@id="rectTop"]').click()
except:
    pass

Xpath进行元素定位|随机数

d = rand.CreatRandomnumbers(1, 4, 1)
ran = d.creatrandomnumbers()
self.driver.find_element_by_xpath('//*[@id="div1"]/div[2]/div['+str(ran[0]) +']/div').click()
import random
class CreatRandomnumbers:
    def __init__(self, start, end, numbercount):
        self.start = start
        self.end = end
        self.numbercount = numbercount
        self.resultlist = []
        self.flag = 0
    def creatrandomnumbers(self):
        tempInt = random.randint(self.start, self.end)
        print(tempInt)
        if(self.flag < self.numbercount):
            if(tempInt not in self.resultlist):
                self.resultlist.append(tempInt)
                self.flag += 1
            self.creatrandomnumbers()
        return self.resultlist

完整代码

from multiprocessing.pool import ThreadPool
from selenium.webdriver.support.ui import WebDriverWait
import time
import random
from selenium.webdriver import Chrome, ActionChains
from selenium.webdriver.chrome.options import Options
import rand
class Wdx():
    def __init__(self):
        chrome_options = Options()
        ran_time = random.randint(1, 10)
        time.sleep(ran_time)
        # re = 代理池代理ip
        # chrome_options.add_argument("--headless")
        # 去除webdriver特征
        chrome_options.add_argument("--disable-blink-features=AutomationControlled")
        chrome_options.add_argument("--proxy-server=" + '代理池')
        # 防止windows识别,添加期权
        chrome_options.add_experimental_option('excludeSwitches', ['enable-automation'])
        chrome_options.add_argument('user-agent=Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/98.0.4758.82 Safar')
        self.driver = Chrome(options=chrome_options)

    def run(self):
        self.driver.get('链接')
        # 开头智能验证
        try:
            self.driver.implicitly_wait(1)
            self.driver.find_element_by_xpath('//*[@id="alert_box"]/div[2]/div[2]/button').click()
            #//*[@id="rectTop"]
            self.driver.find_element_by_xpath('//*[@id="rectTop"]').click()
        except:
            pass
        # 答题区域
        # 1\
        d = rand.CreatRandomnumbers(1, 4, 1)
        ran = d.creatrandomnumbers()
        self.driver.find_element_by_xpath('//*[@id="div1"]/div[2]/div['+str(ran[0]) +']/div').click()
        # 2\
        self.driver.find_element_by_xpath('//*[@id="div2"]/div[2]/div[' + str(random.randint(1, 2)) + ']/div').click()
        #3\
        d = rand.CreateRandomPage(1, 5, 1)
        ran2 = d.createrandompage()
        self.driver.find_element_by_xpath('//*[@id="div3"]/div[2]/div['+str(ran2[0])+']/div').click()
        # 4/
        d = rand.CreateRandomPage(1, 7, 1)
        ran4 = d.createrandompage()
        self.driver.find_element_by_xpath('//*[@id="div4"]/div[2]/div['+str(ran4[0])+']/div').click()
        # 5\
        self.driver.find_element_by_xpath('//*[@id="div5"]/div[2]/div['+ str(random.randint(1, 3)) +']/div').click()
        # 6\
        d = rand.CreateRandomPage(1, 9, 1)
        ran5 = d.createrandompage()
        self.driver.find_element_by_xpath('//*[@id="div6"]/div[2]/div['+str(ran5[0])+']/div').click()
        # self.driver.find_element_by_xpath('//*[@id="div6"]/div[2]/div['+ran5+']/div').click()
        # 7\
        d = rand.CreateRandomPage(1, 9, 1)
        ran6 = d.createrandompage()
        self.driver.find_element_by_xpath('//*[@id="div7"]/div[2]/div['+str(ran6[0])+']/div').click()
        # 8\
        d = rand.CreateRandomPage(1,5,3)
        res = d.createrandompage()
        self.driver.find_element_by_xpath('//*[@id="div8"]/div[2]/div['+str(res[0])+']/div').click()
        self.driver.find_element_by_xpath('//*[@id="div8"]/div[2]/div[' + str(res[1]) + ']/div').click()
        self.driver.find_element_by_xpath('//*[@id="div8"]/div[2]/div[' + str(res[2]) + ']/div').click()
        # 9\
        d = rand.CreateRandomPage(1,5,2)
        res = d.createrandompage()
        self.driver.find_element_by_xpath('//*[@id="div9"]/div[2]/div['+str(res[0])+']/div').click()
        self.driver.find_element_by_xpath('//*[@id="div9"]/div[2]/div[' + str(res[1]) + ']/div').click()
        # 10\
        self.driver.find_element_by_xpath('//*[@id="div10"]/div[2]/div['+str(res[0])+']/div').click()
        self.driver.find_element_by_xpath('//*[@id="div10"]/div[2]/div[' + str(res[1]) + ']/div').click()
        # 11\
        d = rand.CreateRandomPage(1,6,2)
        res = d.createrandompage()
        self.driver.find_element_by_xpath('//*[@id="div11"]/div[2]/div['+str(res[0])+']/div').click()
        self.driver.find_element_by_xpath('//*[@id="div11"]/div[2]/div['+str(res[1]) + ']/div').click()
        # 12\
        self.driver.find_element_by_xpath('//*[@id="div12"]/div[2]/div['+str(random.randint(1,2))+']/div').click()
        # 13
        for i in range(0,3):
            d = rand.CreateRandomPage(1, 6, 3)
            res = d.createrandompage()
            self.driver.find_element_by_xpath('//*[@id="div13"]/div[2]/div['+str(res[0])+']/div').click()

        # 14
        for i in range(0,5):
            d = rand.CreateRandomPage(1, 7, 5)
            res = d.createrandompage()
            self.driver.find_element_by_xpath('//*[@id="div14"]/div[2]/div['+str(res[i])+']/div').click()
        # //*[@id="ctlNext"]
        # 15
        for i in range(0,7):
            d = rand.CreateRandomPage(1, 10, 7)
            res = d.createrandompage()
            self.driver.find_element_by_xpath('//*[@id="div15"]/div[2]/div['+str(res[i])+']/div').click()
        # 16
        for i in range(1,11):
            d = rand.CreateRandomPage(1, 4, 1)
            res = d.createrandompage()
            # //*[@id="drv16_1"]/td[1]/a
            self.driver.find_element_by_xpath('//*[@id="drv16_'+str(i)+'"]/td['+str(res[i])+']/a').click()
        #     17
        for i in range(0,5):
            d = rand.CreateRandomPage(1, 7, 5)
            res = d.createrandompage()
            self.driver.find_element_by_xpath('//*[@id="div17"]/div[2]/div['+str(res[i])+']/div').click()
        # 18
        # //*[@id="div18"]/div[2]/div[1]/div
        d = rand.CreateRandomPage(1,7,5)
        res = d.createrandompage()
        for i in range(0,5):
            self.driver.find_element_by_xpath('//*[@id="div18"]/div[2]/div['+str(res[i])+']/div').click()
        # 结束答题区域
        # 设置等待时间增加答卷真实性
        ran_time = random.randint(150,300)
        time.sleep(ran_time)
        # 点击提交
        self.driver.find_element_by_xpath('//*[@id="ctlNext"]').click()
        # 智能验证
        try:
            self.driver.implicitly_wait(1)
            self.driver.find_element_by_xpath('//*[@id="alert_box"]/div[2]/div[2]/button').click()
            #//*[@id="rectTop"]
            self.driver.find_element_by_xpath('//*[@id="rectTop"]').click()
            self.driver.implicitly_wait(3)
            # 滑块验证
            # 找到滑块
            Hk = self.driver.find_element_by_css_selector("#nc_1_n1z")
            # 整个div滑块
            div_Hk = self.driver.find_element_by_css_selector("#nc_1__scale_text")
            time.sleep(2)
            ActionChains(self.driver).drag_and_drop_by_offset(Hk, div_Hk.size["width"], -div_Hk.size["height"]).perform()
            # 验证之后点击提交
            self.driver.find_element_by_xpath('//*[@id="ctlNext"]').click()
        except:
            pass
        #有时会跳二次验证
        try:
            self.driver.find_element_by_xpath('//*[@id="alert_box"]/div[2]/div[2]/button').click()
            self.driver.find_element_by_xpath('//*[@id="rectTop"]').click()
        except:
            print("这里没有验证")
        print("完成")
        # 运行完毕自动关闭浏览器
        self.driver.quit()

if __name__ == "__main__":
    # Wdx().run()
    for i in range(1,30):
        pool = ThreadPool(5)
        results = pool.map(Wdx().run, range(1, 5))

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值