用python实现提高自己博客访问量
创始人
2024-04-07 08:07:22
0

文章目录

  • 前言
  • 1、整体逻辑
  • 2、代码实现


前言

你还在为自己博客的访问量不高而烦恼吗?我教你如何提高访问量
我发现CSDN上,自己点击自己的博客,可以增加访问量,但是在一定时间内点击同一篇博客,访问量无法再次增加,需要等待一段时间。
通过这个切入点,我们完全可以实现一个非常简单的python小程序,来实现点击博客,提高访问量

1、整体逻辑

本次python小程序的核心就是使用selenium UI测试框架(没有安装的小伙伴需要安装)加上Chrome驱动,Chrome驱动要和Chrome版本大体一致,用其他驱动也可以,例如火狐

第一步
建立一个python项目,并在该项目中建立一个python文件,名字随便(我的叫做increaseTraffic.py),并在当前目录下建立一个文本文件(用于保存xpath,取名为xpath)

第二步:打开浏览器,点击自己博客主页,并按下fn+F12(或者直接按F12)打开开发者模式

在这里插入图片描述

把鼠标移动到自己的第一篇文章上,右击,再点击检查

在这里插入图片描述

将鼠标放到开发者模式中的高亮部分,右击,再将鼠标放到Copy上,左边就会弹出侧边框,里面有一个CopyXpath,然后点击。将这个Xpath拷贝到之前建好的xpath文件中。
再次对第二篇文章进行重复操作,比较两者的Xpath。

例如我的前两篇文章的Xpath:

//*[@id="userSkin"]/div[2]/div/div[2]/div[1]/div[2]/div/div/div[1]/article/a/div[1]/h4
//*[@id="userSkin"]/div[2]/div/div[2]/div[1]/div[2]/div/div/div[2]/article/a/div[1]/h4

仔细对比,只有/article前面的div[1]里面的数字(可以理解为id)不同,代表类似于文章的标号,假如你有50篇文章,里面的id就是1-50,利用这个特性,就不要保存大量的Xpath,使用字符串拼接即可

因此将Xpath分为两部分(id前半部分和后半部分)保存到xpath文件中,例如

在这里插入图片描述

第二步:
读取xpath文件中的内容,并放在一个列表中

def Readfile():with open("./xpath", 'r', encoding="UTF-8") as f:# 不需要读取换行符,因为要进行xpath的拼接filetxt = f.read().splitlines()return filetxt# 将text.txt的数据读到列表中
filetxt = Readfile()
str1 = filetxt[0]
str2 = filetxt[1]

这里需要注意的是不能直接调用readlines(),因为它会读取文件中每行内容的换行,但我们不需要这个换行。

以下是读取换行和不读取换行最终拼接的Xpath的区别:

#不读取换行
//*[@id="userSkin"]/div[2]/div/div[2]/div[1]/div[2]/div/div/div[1]/article/a/div[1]/h4#读取换行
//*[@id="userSkin"]/div[2]/div/div[2]/div[1]/div[2]/div/div/div[
1]/article/a/div[1]/h4

第三步

打开Chrome浏览器,并访问指定的url链接

driver = webdriver.Chrome()
driver.maximize_window()
driver.get("https://blog.csdn.net/qq_56044032?spm=1000.2115.3001.5343")

这里的url链接一定要填自己的,否则就是再给我刷访问量,哈哈

使用Xpath定位并点击有一个前提,右侧的滚动条要逐步向下滚动,否则有些文章可能没有加载,就会导致错误。
除此之外,点击一篇文章后需要关闭该文件,并且driver对象需要进行窗口切换,否则会将主窗口关掉
最后就是当滑动到底部,并且最后一篇文章点击并关闭后,滚动条需要回到最上方

while True:for i in range(1, 80):if(i == 36 or i == 38):driver.execute_script("window.scrollBy(0,143)")continuedriver.find_element_by_xpath(str1 + str(i) + str2).click()print(str1 + str(i) + str2)driver.switch_to.window(driver.window_handles[1])time.sleep(2)driver.close()driver.switch_to.window(driver.window_handles[0])driver.execute_script("window.scrollBy(0,143)")time.sleep(2)driver.execute_script("var q=document.documentElement.scrollTop=0")time.sleep(2)

for中的range是文章数量,做闭右开区间

if(i == 36 or i == 38):driver.execute_script("window.scrollBy(0,143)")continue

这段代码的含义就是跳过除文章外的动态,因为我发了两次动态,它们的是36和38

在这里插入图片描述

它们的Xpath分别是
//[@id=“userSkin”]/div[2]/div/div[2]/div[1]/div[2]/div/div/div[36]/div/a/div[1]/div[1]/div/p
和//
[@id=“userSkin”]/div[2]/div/div[2]/div[1]/div[2]/div/div/div[38]/div/a/div[1]/div[1]/div/p

显然和文章的Xpath不同
跳过点击,但也要进行向下滚动
driver.execute_script(“window.scrollBy(0,143)”) 就是向下滑动143个像素点,保持点击的文章始终在屏幕的中间部分

driver.switch_to.window(driver.window_handles[1])
driver.switch_to.window(driver.window_handles[0])

这两句代码意为切换窗口

driver.execute_script("var q=document.documentElement.scrollTop=0")

这句代码意味,当全部文章都已经点击完毕,需要滑动到最上面,再开始下一轮的点击

2、代码实现

import time
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.common.keys import Keys
from selenium.webdriver.support.ui import Select
from selenium.common.exceptions import NoSuchElementException
from selenium.common.exceptions import NoAlertPresentExceptiondef Readfile():with open("./xpath", 'r', encoding="UTF-8") as f:# 不需要读取换行符,因为要进行xpath的拼接filetxt = f.read().splitlines()return filetxt# 将text.txt的数据读到列表中
filetxt = Readfile()
str1 = filetxt[0]
str2 = filetxt[1]# 打开Chrome浏览器,访问指定的url
driver = webdriver.Chrome()
# Chrome浏览器窗口最大化
driver.maximize_window()
# 到达url链接
driver.get("https://blog.csdn.net/qq_56044032?spm=1000.2115.3001.5343")
time.sleep(3)while True:for i in range(1, 80):if(i == 36 or i == 38):driver.execute_script("window.scrollBy(0,143)")continue# 拼接文章的Xpathdriver.find_element_by_xpath(str1 + str(i) + str2).click()print(str1 + str(i) + str2)# 进行子窗口切换,以至于不是关闭的主窗口driver.switch_to.window(driver.window_handles[1])time.sleep(2)# 关闭子窗口driver.close()# 切换主窗口driver.switch_to.window(driver.window_handles[0])# 向下滑动driver.execute_script("window.scrollBy(0,143)")time.sleep(2)# 回到顶部driver.execute_script("var q=document.documentElement.scrollTop=0")time.sleep(2)driver.quit()

相关内容

热门资讯

监控摄像头接入GB28181平... 流程简介将监控摄像头的视频在网站和APP中直播,要解决的几个问题是:1&...
Windows10添加群晖磁盘... 在使用群晖NAS时,我们需要通过本地映射的方式把NAS映射成本地的一块磁盘使用。 通过...
protocol buffer... 目录 目录 什么是protocol buffer 1.protobuf 1.1安装  1.2使用...
在Word、WPS中插入AxM... 引言 我最近需要写一些文章,在排版时发现AxMath插入的公式竟然会导致行间距异常&#...
Fluent中创建监测点 1 概述某些仿真问题,需要创建监测点,用于获取空间定点的数据࿰...
educoder数据结构与算法...                                                   ...
MySQL下载和安装(Wind... 前言:刚换了一台电脑,里面所有东西都需要重新配置,习惯了所...
MFC文件操作  MFC提供了一个文件操作的基类CFile,这个类提供了一个没有缓存的二进制格式的磁盘...
有效的括号 一、题目 给定一个只包括 '(',')','{','}'...
【PdgCntEditor】解... 一、问题背景 大部分的图书对应的PDF,目录中的页码并非PDF中直接索引的页码...