python爬虫_selenuim登录个人markdown博客站点

news2024/9/24 17:18:36

文章目录

    • ⭐前言
    • ⭐selelunim
    • ⭐博客站点
      • 💖 自动填充账号密码登录
    • ⭐结束

yma16-logo

⭐前言

大家好,我是yma16,本文分享python使用selenuim登录个人markdown博客站点。
该系列文章:
python爬虫_基本数据类型
python爬虫_函数的使用
python爬虫_requests的使用
python爬虫_selenuim可视化质量分
python爬虫_django+vue3可视化csdn用户质量分
python爬虫_正则表达式获取天气预报并用echarts折线图显示
python爬虫_requests获取bilibili锻刀村系列的字幕并用分词划分可视化词云图展示

⭐selelunim

Selenium是一个用于Web应用程序测试的开源自动化测试工具,它可以模拟用户在Web浏览器上的操作,如点击、填写表单、提交表单等。Selenium支持多种编程语言,如Java、Python、C#等,可以在不同的平台上运行,如Windows、macOS、Linux等。使用Selenium自动化可以提高测试的效率和准确性,减少人工测试的工作量,同时也可以节省测试成本。

XPath定位
XPath是用来定位XML文档节点的语言
常用方法:

  • find_element_by_xpath 查找元素
  • send_keys 传递值
  • click 点击事件

⭐博客站点

个人博客站点:https://yongma16.xyz/#/login
login-page

登录html文件内容查看
vue打包之后浏览器渲染的html

<html>
	<head>
		<meta charset="utf-8">
		<meta name="viewport" content="width=device-width,initial-scale=1">
		<title>yma16前端日记</title>
		<link rel="shortcut icon" href="./myblog_static/utils/fx_background/image/logo.ico">
		<link rel="stylesheet" href="./myblog_static/utils/fx_background/css/core.css">
		<style>
			body {
				overflow: hidden;
				background: url("https://yongma16.xyz/staticFile/common/img/blogScene.jpg");
				background-position: center center;
				background-clip: border-box;
				background-repeat: no-repeat;
			}
		</style>
		<link href="./myblog_static/css/app.eee4c67a62a22d8f583d237d4e2e6665.css" rel="stylesheet">
		<style type="text/css">
			.icon {
				width: 1em;
				height: 1em;
				vertical-align: -0.15em;
				fill: currentColor;
				overflow: hidden;
			}
		</style>
		<script type="text/javascript" charset="utf-8" async="" src="./myblog_static/js/2.badf9bda58d6b138d639.js">
		</script>
	</head>
	<body>
		<div id="app">
			<section class="el-container"><!---->
				<section class="el-container is-vertical">
					<header class="el-header" style="height: 60px;"><a style="cursor: pointer;"><i
								class="el-icon-s-promotion"></i>&nbsp;&nbsp;<span
								style="font-weight: bold;">yma16</span></a>
						<div
							style="float: right; overflow: hidden; display: flex; place-items: center; word-spacing: 16px;">
							<!----> <a href="https://codechina.csdn.net/qq_38870145/myblogvue"><img
									src="./myblog_static/img/code-china.06a17a9.png"
									style="cursor: pointer; height: 16px;"></a> <a
								href="https://github.com/yongma16"><img
									src=""
									style="cursor: pointer; height: 16px;"></a></div>
					</header>
					<main class="el-main mainappclass" id="mainappid">
						<div data-v-df1f4c12="" class="login" style="text-align: center; width: 100%;">
							<div data-v-df1f4c12="" class="el-card box-card is-always-shadow"
								style="text-align: center;"><!---->
								<div class="el-card__body">
									<div data-v-df1f4c12="" style="flex: 1 1 0%; margin: 0px auto;">
										<form data-v-df1f4c12="" class="el-form">
											<div data-v-df1f4c12="" class="el-form-item el-form-item--feedback"><!---->
												<div class="el-form-item__content">
													<p data-v-df1f4c12="" style="font-size: 30px;">登录</p><!---->
												</div>
											</div>
											<div data-v-df1f4c12="" class="el-form-item el-form-item--feedback"><!---->
												<div class="el-form-item__content">
													<div data-v-df1f4c12="" class="el-input"><!----><input type="text"
															autocomplete="off" placeholder="请输入账号"
															class="el-input__inner"><!----><!----><!----><!----></div>
													<!---->
												</div>
											</div>
											<div data-v-df1f4c12="" class="el-form-item el-form-item--feedback"><!---->
												<div class="el-form-item__content">
													<div data-v-df1f4c12="" class="el-input el-input--suffix">
														<!----><input type="password" autocomplete="off"
															placeholder="请输入密码" class="el-input__inner"><!----><span
															class="el-input__suffix"><span
																class="el-input__suffix-inner"><!----><!----><!----><!----></span><!----></span><!----><!---->
													</div><!---->
												</div>
											</div>
											<div data-v-df1f4c12="" class="el-form-item el-form-item--feedback"><!---->
												<div class="el-form-item__content"><button data-v-df1f4c12=""
														type="button"
														class="el-button el-button--primary"><!----><!----><span>登录</span></button>
													<button data-v-df1f4c12="" type="button"
														class="el-button el-button--default"><!----><!----><span>清空</span></button><!---->
												</div>
											</div>
											<div data-v-df1f4c12="" class="el-form-item el-form-item--feedback"><!---->
												<div class="el-form-item__content"><a data-v-df1f4c12="" target="_blank"
														class="el-link el-link--default is-underline"><!----><span
															class="el-link--inner">没有账号?</span><!----></a> <a
														data-v-df1f4c12=""
														class="el-link el-link--primary is-underline"><!----><span
															class="el-link--inner">去注册</span><!----></a><!----></div>
											</div>
											<div data-v-df1f4c12="" class="el-form-item el-form-item--feedback"><!---->
												<div class="el-form-item__content">
													<div data-v-df1f4c12="" style="width: 100%;">
														<div data-v-df1f4c12=""
															class="el-divider el-divider--horizontal">
															<div data-v-df1f4c12="" class="el-divider__text is-center">
																其他登录</div>
														</div>
														<div data-v-df1f4c12="" style="display: flex; width: 100%;">
															<div data-v-df1f4c12=""
																style="width: 50%; text-align: center;"><img
																	data-v-df1f4c12=""
																	src="https://ts2.cn.mm.bing.net/th?id=ODLS.f9daea21-9936-4164-815f-b5209459f3c6&amp;w=32&amp;h=32&amp;qlt=90&amp;pcl=fffffa&amp;o=6&amp;pid=1.2"
																	style="width: 10px; line-height: 56px;"> <a
																	data-v-df1f4c12=""
																	class="el-link el-link--primary is-underline"><!----><span
																		class="el-link--inner">微软登录(alpha)</span><!----></a>
															</div>
															<div data-v-df1f4c12=""
																style="width: 50%; text-align: center;"><img
																	data-v-df1f4c12=""
																	src="https://sola.gtimg.cn/aoi/sola/20210118201807_hzF9zYwEBj.png"
																	style="width: 10px; line-height: 56px;"> <a
																	data-v-df1f4c12=""
																	class="el-link el-link--primary is-underline"><!----><span
																		class="el-link--inner">QQ登录(alpha)</span><!----></a>
															</div>
														</div>
													</div><!---->
												</div>
											</div>
										</form>
									</div>
								</div>
							</div>
						</div>
					</main>
					<footer class="el-footer" style="height: 60px;">
						<div class="design-footer">
							<div class="footer_font">
								<div style="float: left;"></div> <span>
									Copyright ©2021-2023 yongma16.xyz
									个人空间&nbsp;&nbsp;&nbsp;</span> <span> 足迹:15810&nbsp;&nbsp;&nbsp;</span> <span><img
										src=""
										style="cursor: pointer; height: 16px; margin-bottom: 0px; padding-bottom: 0px;">&nbsp;&nbsp;<span
										style="cursor: pointer;">黔ICP备20001426号-1</span></span>
							</div>
						</div>
					</footer>
				</section>
			</section>
		</div>
		<div id="canvas">
			<div id="life"></div>
			<div id="is"></div>
			<div id="beautiful"></div>
		</div>
		<script type="text/javascript" src="./myblog_static/js/manifest.6170dd2794b530d87ce4.js"></script>
		<script type="text/javascript" src="./myblog_static/js/vendor.897bbe519228c0b3deec.js"></script>
		<script type="text/javascript" src="./myblog_static/js/app.03f00ca1922f6fc64df7.js"></script>
		<script src="https://eqcn.ajz.miesnfu.com/wp-content/plugins/wp-3d-pony/live2dw/lib/L2Dwidget.min.js"></script>
		<script src="https://yongma16.xyz/static/aliyunIcon/icon.js"></script>
		<script>
			L2Dwidget.init({
				model: {
					jsonPath: "https://unpkg.com/live2d-widget-model-haruto@1.0.5/assets/haruto.model.json",
					scale: 1,
					hHeadPos: 0.5,
					vHeadPos: 0.618,
				},
				display: {
					position: "center",
					width: 50,
					height: 60,
					hOffset: 0,
					vOffset: 0,
				},
				mobile: {
					show: true,
					scale: 0.5,
				},
				react: {
					opacityDefault: 0.9,
					opacityOnHover: 0.5,
				},
			});
		</script>
	</body>
</html>

💖 自动填充账号密码登录

思路分解:
1.查找账号输入框,赋值
2.查找密码输入框,赋值
3.查找登录按钮,点击click

实现代码如下:

from selenium import webdriver
import time,json


dir_path='C:\\Users\MY\PycharmProjects\Spider_python\study2021\day07\dirver\msedgedriver.exe'
driver = webdriver.Edge(executable_path=dir_path)
url = 'https://yongma16.xyz/#/login'
# 浏览器访问登录
def startAction():
    driver.get(url)
    autoWriteAccount()

# 自动填写
def autoWriteAccount():
    username='阳光罐里的日记'
    pwd='1998'
    driver.find_element_by_xpath('//input[@type="text" and @placeholder="请输入账号"]') \
        .send_keys(username)  # 输入账号
    driver.find_element_by_xpath('//input[@type="password" and @placeholder="请输入密码"]') \
        .send_keys(pwd)  # 输入密码
    submitBtn()

# 登录
def submitBtn():
    driver.find_element_by_xpath('//button[@type="button"]') \
        .click()  # 点击第一个按钮


if __name__=='__main__':
    startAction()
    driver.close()





实现效果:
在这里插入图片描述

⭐结束

本文分享到这结束,如有错误或者不足之处欢迎指出!
scene

👍 点赞,是我创作的动力!
⭐️ 收藏,是我努力的方向!
✏️ 评论,是我进步的财富!
💖 感谢你的阅读!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/739036.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

接口中的默认方法和静态方法

接口中的默认方法和静态方法 接口中的默认方法 package cn.tedu.inter; //1.定义接口 public interface Inter1 {/*1.接口中默认方法的修饰符public可以省略*///2.定义接口中的默认方法public default void play(){System.out.println("我是接口中的默认方法&#xff0c;…

OSPFv2基础03_综合实验

目录 1.创建OSPF进程 2.创建OSPF区域 3.使能OSPF 4.创建虚连接&#xff08;可选&#xff09; 5.OSPF常用命令 6.实验配置步骤 7.实验效果 1.创建OSPF进程 OSPF是一个支持多进程的动态路由协议&#xff0c;OSPF多进程可以在同一台路由器上运行多个不同的OSPF进程&#x…

ES6基本知识点

目录 1.对象优化 1.1 新增API 1.2 object.assign方法的第一个参数是目标对象&#xff0c;后面的参数都是源对象 1.3 声明对象简写 1.4 对象的函数属性简写 1.5 对象拓展运算符 2.map和reduce 2.1 数组中新增的map和reduce方法 3 promise 3.1 promise封装异步操作 4.模…

C# PaddleInference OCR 验证码识别

说明 C# PaddleInference OCR 验证码识别 自己训练的模型&#xff0c;只针对测试图片类型&#xff0c;准确率99% 效果 项目 VS2022.net4.8OpenCvSharp4Sdcb.PaddleInference 测试图片 代码 using OpenCvSharp; using Sdcb.PaddleInference.Native; using Sdcb.PaddleInfer…

mac笔记本安装java环境以及idea设置

系列文章目录 文章目录 系列文章目录安装java环境一、安装jdk二、下载安装IntelliJ IDEA三、安装maven四、安装git五、安装tomcat六、安装appenv配置文件七、有关idea的设置1、快捷键设置2、新建类的命名3、字体的大小&#xff0c;有关菜单栏的大小4、框内的tab最多能有多少个窗…

【2 beego学习 - 项目导入与项目知识点】

0 项目导入 1 在英文路径下新建一个同名的项目,拷贝其他数据到这个文件 bee new 同名项目名 cd 同名项目名 go mod tidy go get -u -v github.com/astaxie/beego go get 同名项目名/models2 拷贝部分的项目文件到新目录 bee run 运行的其他错误,按照提示安装文件 1 后端获取…

微软MFC技术中的消息队列及消息处理

我是荔园微风&#xff0c;作为一名在IT界整整25年的老兵&#xff0c;今天来聊聊微软MFC技术中的消息队列及消息处理。 MFC应用程序中由Windows 系统以消息的形式发送给应用程序的窗口。窗口接收和处理消息之后&#xff0c;把控制返回给Windows。Windows系统在同一时间可显示多…

HashMap底层原理:数据结构+put()流程+2的n次方+死循环+数据覆盖问题

导航&#xff1a; 【Java笔记踩坑汇总】Java基础进阶JavaWebSSMSpringBoot瑞吉外卖SpringCloud黑马旅游谷粒商城学成在线MySQL高级篇设计模式常见面试题源码_vincewm的博客-CSDN博客 目录 一、底层 1.1 HashMap数据结构 1.2 扩容机制 1.3 put()流程 1.4 HashMap是如何计算…

电话号码的字母组合问题

解题思路&#xff1a; 当我第一眼看到这题的时候&#xff0c;我直接举出来一个列子“258”&#xff0c;直接套用多重for循环遍历可以罗列出来&#xff0c;但是根据数字组合的长度不能确定for循环的多少&#xff08;除非把所有for循环个数情况都罗列一遍&#xff09; 所以只能…

几种常用接口调用方式介绍

API&#xff0c;全称叫做Application Programming interface&#xff0c;也就是应用程序接口&#xff0c;API是一些预先定义的函数&#xff0c;我是学Java的&#xff0c;当我要使用这些函数的时候&#xff0c;便可以直接调用Java API&#xff0c;不用去访问源码&#xff0c;也不…

Linux设备驱动程序(四)——调试技术

文章目录 前言一、内核中的调试技术二、通过打印调试1、printk2、重定向控制台消息3、消息如何被记录4、开启及关闭消息5、速度限制6、打印设备编号 三、通过查询调试1、使用 /proc 文件系统①、在/proc中实现文件②、创建自己的 /proc 文件③、seq_file 接口 2、ioctl 方法 四…

Chatbot UI 和 ChatGLM2-6B 的集成

Chatbot UI 和 ChatGLM2-6B 的集成 0. 背景1. 部署 Chatbot UI2. 部署 ChatGLM2-6B3. 修改 ChatGLM2-6B 项目的 openai_api.py4. 修改 Chatbot UI 的配置5. 访问 Chatbot UI 0. 背景 尝试将 Chatbot UI 和 ChatGLM2-6B 的进行集成&#xff0c; ChatGLM2-6B 提供 API 服务&…

精确时钟同步协议ptp/IEEE-1588v2协议-------(2)主从时钟之间的消息交互与时钟同步过程

本文目录 1、主时钟和从时钟之间的消息交互流2、延时delay和偏移offset的计算2.1、延时delay的计算2.2、偏移offset的计算 主时钟和从时钟之间&#xff0c;通过sync, follow up, delay request, delay response这四条消息&#xff0c;完成时钟同步过程。PTP时钟同步系统能工作的…

word绘制横向表格

最近写小论文&#xff0c;表格太宽需要绘制横向表格&#xff0c;找了半天教程说的都不是很详细&#xff0c;我学习了一下决定自己写个教程。 我要在一和二之间创建一个横向表格。首先在一后面添加一个分节符号。布局->分隔符->分节负下一页。 再在二之前添加一个分节符号…

新耀东方|安全狗亮相2023第二届上海网络安全博览会

7月5日至7日&#xff0c;“新耀东方-2023第二届上海网络安全博览会暨高峰论坛”在上海顺利举办。此次大会由上海市信息网络安全管理协会、国家计算机网络应急技术处理协调中心上海分中心、(ISC)2上海分会、上海市普陀区科学技术委员会、上海市网络安全产业示范园共同主办。 作为…

左神算法之中级提升(2)

目录 [案例1】 【题目描述】 【思路解析1】 【思路解析2】 【代码实现】 【案例2】 【题目描述】 【思路解析】 【代码实现】 【案例3】 【题目描述】 【思路解析】 【代码实现】 【案例4】 【题目描述】今日头条2018面试题 第四题 【输入描述】 【思路解析】 【…

对于没有任何基础的初学者,云计算该怎样学习?

想学习任何一门专业技能&#xff0c;可以按下面这一套逻辑梳理&#xff01; 1&#xff09;了解基本内容 云计算这个技术是做什么的&#xff1f;适用哪些场景&#xff1f;有什么优点和缺点&#xff1f; 同时建议先找技术大纲&#xff0c;至少要学哪些技能点&#xff0c;可以网…

Layui之入门

目录 一、layui介绍 1.是什么 2.谁开发的 3.特点 二、layui&#xff0c;easyui和bootstrap的区别 1.layui、easyui与bootstrap的对比 2. layui和bootstrap对比&#xff08;这两个都属于UI渲染框架&#xff09; 3. layui和easyui对比 三、基础使用 四、登录注册实例讲解 …

医院陪诊小程序开发|陪诊小程序定制|陪诊服务app成品

陪诊小程序的功能开发对于陪诊行业有以下好处&#xff1a;   提高服务效率&#xff1a;陪诊小程序可以提供在线预约功能&#xff0c;方便用户随时预约合适的陪诊人员&#xff0c;减少了繁琐的人工沟通和安排工作&#xff0c;提高了服务效率。   增加服务范围&#xff1a;通…

基于matlab将图像标记器多边形转换为标记的块图像以进行语义分割(附源码)

一、前言 此示例演示如何将存储在对象中的多边形标签转换为适用于语义分割工作流的标记阻止图像。 可以使用计算机视觉工具箱中的图像标记器应用来标记太大而无法放入内存和多分辨率图像的图像。有关详细信息&#xff0c;请参阅在图像标记器&#xff08;计算机视觉工具箱&…