IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Python知识库 -> 模拟人工悄悄跳过滑块检索登入TB -> 正文阅读

[Python知识库]模拟人工悄悄跳过滑块检索登入TB

代码传送门

打开淘宝,并成功模拟登入

模拟登入第一步,TB会被发现自动化控制,所以要不被发现才行,如下:

options = webdriver.ChromeOptions()
#隐藏window.navigator.webdriver,禁用启用Blink运行时的功能
options.add_argument("--disable-blink-features=AutomationControlled")
# 设置为开发者模式,防止网站识别
#chrome 不显示正受到自动测试软件的控制
options.add_experimental_option(
    'excludeSwitches', ['enable-automation'])
driver = webdriver.Chrome(options=options)

寻找账号密码登入框

寻找登入框各部分,直接输入账号密码自动运行

def Running(user,pswd):
    try:
      #  element=driver.find_element(By.CLASS_NAME,'h').click()
        element = driver.find_element(By.XPATH,'//*[@id="fm-login-id"]')
        ActionChains(driver).move_to_element(element).perform()
        sleep(0.5)
        element.click()
        element.send_keys(user)
        sleep(0.5)  
        element = driver.find_element(By.XPATH,'//*[@id="fm-login-password"]')
        ActionChains(driver).move_to_element(element).perform()
        sleep(0.5)
        element.click()
        element.send_keys(pswd)
        sleep(0.5)
        # driver.back()回退一步
        element = driver.find_element(By.XPATH,'//button[text()="登录"]').click()
        sleep(0.5)
        #当前句柄
        now_handle = driver.current_window_handle
        print(now_handle)
     #   element = driver.find_element(By.XPATH ,'//input[@name="q"]')
        currentPageUrl = driver.current_url
        print("当前页面的url是:", currentPageUrl)
        
    except Exception as e:
        print(e)

切记:只要不多次频繁登入就不会出现扫码环节

寻找搜索框输入所需信息

element.send_keys(‘需要搜索的物品’)

搜素之前判断是否进入主页,看看是否卡在登入界面

def Search(url):
    currentPageUrl = driver.current_url
    print("当前页面的url是:", currentPageUrl)
    driver.get(url)

    #找搜索框
    element = driver.find_element(By.XPATH,'//input[@name="q"]')
    element.send_keys('充电宝')
    element = driver.find_element(By.XPATH ,'//button[text()="搜索"]').click()
    print(element)

找到商品,爬取信息

找到商品后爬取有用信息并保存到Variable Explorer下

def Find_info(hrefs_,imgs_list,texts_list):
    # currentPageUrl = driver.current_url
    # print("当前页面的url是:", currentPageUrl)
    sleep(0.5)
    for link in driver.find_elements(By.XPATH,'//div[@class="row row-2 title"]/a'):
        sleep(0.1)
        hrefs_.append(link.get_attribute('href'))
#        print(hrefs_)
    for link in driver.find_elements(By.XPATH,'//div[@class="pic"]/a/img'):
        sleep(0.1)
        imgs_list .append(link.get_attribute('src'))
#        print(imgs_list)
    for link in driver.find_elements(By.XPATH,'//div[@class="row row-2 title"]/a'):
        sleep(0.1)
        #信息已隐藏,可以用.is_displayed()来判断是否隐藏
        texts_list.append(link.get_attribute('textContent').strip())
#        print(texts_list)
    #1、通过直接接入网址进入下一页进行搜索,切换到第二页。
    #2、也可以输入0-100页点确定按钮
    return hrefs_,imgs_list,texts_list

后续设计UI界面,搜索最优物品,保存如csv中…

如果能省下大佬们搜索的时间的话给弟弟一个赞把😘😘😘
嘿嘿!ψ(`?′)ψ

  Python知识库 最新文章
Python中String模块
【Python】 14-CVS文件操作
python的panda库读写文件
使用Nordic的nrf52840实现蓝牙DFU过程
【Python学习记录】numpy数组用法整理
Python学习笔记
python字符串和列表
python如何从txt文件中解析出有效的数据
Python编程从入门到实践自学/3.1-3.2
python变量
上一篇文章           查看所有文章
加:2022-01-17 11:28:10  更:2022-01-17 11:30:46 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/16 1:36:11-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码