Python+selenium 自动化-读取excel记录的脚本执行登陆操作实战演示

简介: Python+selenium 自动化-读取excel记录的脚本执行登陆操作实战演示

我们可以用 excel 来记录自动化,然后读取 excel 来执行命令,excel 可以很方便直观的管理我们录入的自动化。下面给大家演示一下 Python+selenium 自动化的实例,读取 excel 执行登陆操作。

首先如果想要操控 excel 需要两个库 xlrdxlwt,一个是读,一个是写。

本章我想通过 python 读取 excel 里我设置的一些字段,来执行一个登陆操作。

def read_xl():
  # 打开excel
  workbook = xlrd.open_workbook('login.xlsx')
  sheet = workbook.sheets()[0] # 代表第一个页签,excel是可以有多个页签的
  nrows = sheet.nrows # 看excel一共有多少行内容
  # 一行一行的读取内容,sheet.row_values(i)[0]代表该行的第一个单元格
  for i in range(nrows):
    sw(sheet.row_values(i)[0],sheet.row_values(i)[1],sheet.row_values(i)[2],sheet.row_values(i)[3],sheet.row_values(i)[5])

下面是我设置的 excel 字段,以及每个字段的含义。

image.png

下面这是完整版,我是结合 python+selenium 来操控我的 chrome 浏览器,excel 读取的字段通过我的 sw() 方法转化为对应操作浏览器的命令来执行。

当然这里的地址是内网的,是只有我才可以用的。excel 附件里的登陆名和密码也是只有我自己才可以用的,这些需要你自己来设置。

Excel 附件:小蓝枣的资源仓库 提取码:b2av

# -*- coding: UTF-8 -*-
# excel说:感觉自己被操控
# excel读写库
import xlrd
import xlwt
# selenium浏览器驱动
from selenium import webdriver
import time
# 初始化Chrome()
driver = webdriver.Chrome()
driver.maximize_window()
driver.implicitly_wait(5) #单位秒
# 登陆
def login():
  # 我自己可用的内网ip地址
  url="http://172.20.xx.xx:8102"
  print("你的小可爱正在打开: "+url+"   请看好她!!!\n")
  driver.get(url)  
# excel读取
def read_xl():
  # 打开excel
  workbook = xlrd.open_workbook('login.xlsx')
  sheet = workbook.sheets()[0] # 代表第一个页签,excel是可以有多个页签的
  nrows = sheet.nrows # 看excel一共有多少行内容
  # 一行一行的读取内容,sheet.row_values(i)[0]代表该行的第一个单元格
  for i in range(nrows):
    sw(sheet.row_values(i)[0],sheet.row_values(i)[1],sheet.row_values(i)[2],sheet.row_values(i)[3],sheet.row_values(i)[5])
# 转化excel读取的操作
def sw(a,b,c,d,e):
  k=1
  if a=='click':
    action(e)
    sw_click(b,c)
  elif a=='input':
    action(e)
    sw_input(b,c,d)
  elif a=='wait':
    action("等待")
    sw_wait(d)
  elif a=='open':
    action(e)
    sw_open(d)
    print('open操作无效,如有需要请找管理员对open解禁')
  else:
    k=0
  time.sleep(2)
  if k==1:
    print("该命令执行结束!\n")
def action(e):
  print("正在进行: "+e+"   请稍后...")
def sw_click(b,c):
  if b=='id':
    driver.find_element_by_id(c).click()
  elif b=='xpath':
    driver.find_element_by_xpath(c).click()
def sw_input(b,c,d):
  if b=='id':
    driver.find_element_by_id(c).send_keys(d)
  elif b=='xpath':
    driver.find_element_by_xpath(c).send_keys(d)
def sw_wait(d):
  time.sleep(d/1000)
def sw_open(d):
  time.sleep(1)
login()
read_xl()

读取执行内容的同时,后台会同时播报正在执行的命令。

image.png

喜欢的可以点个赞❤!


目录
相关文章
|
3月前
|
SQL 关系型数据库 数据库
Python SQLAlchemy模块:从入门到实战的数据库操作指南
免费提供Python+PyCharm编程环境,结合SQLAlchemy ORM框架详解数据库开发。涵盖连接配置、模型定义、CRUD操作、事务控制及Alembic迁移工具,以电商订单系统为例,深入讲解高并发场景下的性能优化与最佳实践,助你高效构建数据驱动应用。
468 7
|
3月前
|
数据采集 Web App开发 数据安全/隐私保护
实战:Python爬虫如何模拟登录与维持会话状态
实战:Python爬虫如何模拟登录与维持会话状态
|
3月前
|
传感器 运维 前端开发
Python离群值检测实战:使用distfit库实现基于分布拟合的异常检测
本文解析异常(anomaly)与新颖性(novelty)检测的本质差异,结合distfit库演示基于概率密度拟合的单变量无监督异常检测方法,涵盖全局、上下文与集体离群值识别,助力构建高可解释性模型。
378 10
Python离群值检测实战:使用distfit库实现基于分布拟合的异常检测
|
3月前
|
数据采集 监控 数据库
Python异步编程实战:爬虫案例
🌟 蒋星熠Jaxonic,代码为舟的星际旅人。从回调地狱到async/await协程天堂,亲历Python异步编程演进。分享高性能爬虫、数据库异步操作、限流监控等实战经验,助你驾驭并发,在二进制星河中谱写极客诗篇。
Python异步编程实战:爬虫案例
|
3月前
|
Cloud Native 算法 API
Python API接口实战指南:从入门到精通
🌟蒋星熠Jaxonic,技术宇宙的星际旅人。深耕API开发,以Python为舟,探索RESTful、GraphQL等接口奥秘。擅长requests、aiohttp实战,专注性能优化与架构设计,用代码连接万物,谱写极客诗篇。
Python API接口实战指南:从入门到精通
|
3月前
|
存储 分布式计算 测试技术
Python学习之旅:从基础到实战第三章
总体来说,第三章是Python学习路程中的一个重要里程碑,它不仅加深了对基础概念的理解,还引入了更多高级特性,为后续的深入学习和实际应用打下坚实的基础。通过这一章的学习,读者应该能够更好地理解Python编程的核心概念,并准备好应对更复杂的编程挑战。
149 12
|
4月前
|
数据采集 存储 XML
Python爬虫技术:从基础到实战的完整教程
最后强调: 父母法律法规限制下进行网络抓取活动; 不得侵犯他人版权隐私利益; 同时也要注意个人安全防止泄露敏感信息.
821 19
|
3月前
|
存储 数据采集 监控
Python文件操作全攻略:从基础到高级实战
本文系统讲解Python文件操作核心技巧,涵盖基础读写、指针控制、异常处理及大文件分块处理等实战场景。结合日志分析、CSV清洗等案例,助你高效掌握文本与二进制文件处理,提升程序健壮性与开发效率。(238字)
407 1
|
3月前
|
存储 Java 调度
Python定时任务实战:APScheduler从入门到精通
APScheduler是Python强大的定时任务框架,通过触发器、执行器、任务存储和调度器四大组件,灵活实现各类周期性任务。支持内存、数据库、Redis等持久化存储,适用于Web集成、数据抓取、邮件发送等场景,解决传统sleep循环的诸多缺陷,助力构建稳定可靠的自动化系统。(238字)
679 1
|
4月前
|
设计模式 人工智能 API
AI智能体开发实战:17种核心架构模式详解与Python代码实现
本文系统解析17种智能体架构设计模式,涵盖多智能体协作、思维树、反思优化与工具调用等核心范式,结合LangChain与LangGraph实现代码工作流,并通过真实案例验证效果,助力构建高效AI系统。
604 7

热门文章

最新文章

推荐镜像

更多