pyppeteer对于iframe中的滑块

复制
import asyncio
import time
import numpy, random
import pyppeteer
async def main():
    ip = "xxxxxx"      #代理ip
    port = "xxxx"      #代理端口
    browser = await pyppeteer.launch({'headless': False,
                                      'args': [
                                          '--window-size={1300},{600}'
                                          '--disable-extensions',
                                          '--hide-scrollbars',
                                          '--disable-bundled-ppapi-flash',
                                          '--mute-audio',
                                          '--no-sandbox',
                                          '--disable-setuid-sandbox',
                                          '--disable-gpu',
                                          '--disable-infobars'
                                          f'--proxy-server={ip}:{port}'
                                      ],
                                      'dumpio': True
                                      })

    page = await browser.newPage()    #打开一个新页面



    await page.goto('url')   #你要去的页面
    time.sleep(1)
    await page.setUserAgent('5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/87.0.4280.88 Safari/537.36')
    await page.evaluateOnNewDocument('() =>{ Object.defineProperties(navigator,'
                                          '{ webdriver:{ get: () => undefined } }) }')
    await page.evaluateOnNewDocument('() =>{ Object.defineProperties(navigator,'
                                          '{ appVersion:{ get: () => 5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/87.0.4280.88 Safari/537.36 } }) }')

    frame = page.frames   #获取所有的iframe
    iframe = frame[1]
    await iframe.hover("#nc_1_n1z")   #iframe中的元素聚焦
    await page.mouse.down()
    # time.sleep(1000)

    # 3 滑动
    print(random_linspace(100,800))
    start = 0
    end = 0
    for a in random_linspace(4,800):
        a = int(a)
        print(f'滑动{a}')
        end +=a
        print(end, start)
        await  page.mouse.move(end, start)
        start=end




def random_linspace(num, length):

    start, end = 0.5 * (length / num), 1.5 * (length / num)
    # 借助三方库生成一个标准的等差数列,主要是得出标准等差 space
    origin_list = numpy.linspace(start, end, num)
    space = origin_list[2] - origin_list[1]
    # 在标准等差的基础上,设置上下浮动的大小,(上下浮动10%)
    min_random, max_random = -(space / 10), space / 10
    result = []
    # 等差数列的初始值不变,就是我们设置的start
    value = start
    # 将等差数列添加到 list
    result.append(value)
    # 初始值已经添加,循环的次数 减一
    for i in range(num - 1):
        # 浮动的等差值 space
        random_space = space + random.uniform(min_random, max_random)
        value += random_space
        result.append(value)
    return result



asyncio.get_event_loop().run_until_complete(main())
posted @   小小咸鱼YwY  阅读(1485)  评论(4编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
历史上的今天:
2019-12-17 tornado框架中redis使用
点击右上角即可分享
微信分享提示