用Python实现一个CSDN自动三连工具

简介: 用Python实现一个CSDN自动三连工具

对于CSDN自动三连工具,大佬小小明很早就实现了一个 GUI 版本的工具,具体页面如下

从界面就可以看出,这款工具还是非常强大而且功能也相当齐全了,喜欢的朋友可以去小明哥的CSDN上查找哈。

工具虽好,不过还是有一个缺点,就是不方便每天自动化运行,那么今天我们就来实现一款可以每天自动运行的三连工具

实现思路

如果把工具实现成 GUI 的形式,类似上面的做法,确实方便用户使用了,但是却不利于自动运行,所以我们可以实现成后台应用的形式,比如直接编写代码调用相关接口,然后使用 crontab 来做定时运行

于是我们可以完成如下的代码构造

class CSDN:
    def __init__(self):
        ...
    def getHotRank(self):
        ...
    def likePost(self, articleId):
        ...
    def buryPost(self, articleId):
        ...
    def favoritePost(self, details, articleId):
        ...
    def submitPost(self, articleId, comment):
        ...
    def followPost(self):
        ...

首先是从热榜中获取相关文章信息,然后就是进行点赞,收藏,留言和关注的操作了

接口请求

我们首先在 CSDN 热榜页面进行抓包,通过 F12 可以非常方便 看到热榜的相关请求如下

"https://blog.csdn.net/phoenix/web/blog/hot-rank?page=0&pageSize=25&type="

那么获取热榜数据的代码如下

def getHotRank(self):
    HotRankUrl = config.Hot_Rank
    hot_rank = requests.get(HotRankUrl, headers=self.headers)
    return hot_rank.json()

就是最简单的 request 请求,当时这里的 headers 我们是在构造函数中定义的,且 headers 中包含你登录的 cookie 信息

接下来我们通过同样的方式,分别抓取 like,submit 和 favorite 记忆 follow 接口

下面我们只给出 favorite 的代码,其余代码大家可以自行完成

def favoritePost(self, details, articleId):
    fav_userName = self.cookie.split("UserName=")[-1].split(";")[0]
    articleTitle = details["articleTitle"]
    articleDetailUrl = details["articleDetailUrl"]
    userName = details["userName"]
    self.favorite_json["username"] = fav_userName
    self.favorite_json["author"] = userName
    self.favorite_json["url"] = articleDetailUrl
    self.favorite_json["title"] = articleTitle
    self.favorite_json["sourceId"] = articleId
    favUrl = config.Favorite_Post
    payload = json.dumps(self.favorite_json)
    headers = self.headers
    headers['Content-Type'] = 'application/json'
    favoritepost = requests.post(favUrl, headers=headers, data=payload)
    print(favoritepost.json())

最后,我们完成整个脚本的调用

if __name__ == '__main__':
    csdn = CSDN()
    data = csdn.getHotRank()
    details_list = data["data"]
    with open("comment.txt", "r") as f:
        comment = f.readlines()
    for i in details_list:
        num_items = len(comment)
        random_index = random.randrange(num_items)
        random_comment = comment[random_index]
        articleId = i["productId"]
        csdn.likePost(articleId)
        csdn.favoritePost(i, articleId)
        csdn.submitPost(articleId, random_comment)
        random_time = random.randint(1, 30)
        time.sleep(random_time)

这里我们提前准备好了留言的模板文件,然后随机从文件中选择一条留言信息进行请求操作

定时运行

最后我们把整个脚本部署到自己的 Linux 服务器上,萝卜哥这里使用的是阿里云,当前其他的腾讯云,华为云等都是类似的

我们先登录云服务器,我这里用的工具是 MobaX

然后直接设置 crontab 文件即可

我这里设置了每天5点定时执行该脚本,现在再也不用每天打开上面的 GUI 软件来手工执行了,舒服!

好了,这就是今天分享的全部内容,喜欢就点个吧~

相关文章
|
2天前
|
JavaScript 前端开发 Android开发
【03】仿站技术之python技术,看完学会再也不用去购买收费工具了-修改整体页面做好安卓下载发给客户-并且开始提交网站公安备案-作为APP下载落地页文娱产品一定要备案-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
【03】仿站技术之python技术,看完学会再也不用去购买收费工具了-修改整体页面做好安卓下载发给客户-并且开始提交网站公安备案-作为APP下载落地页文娱产品一定要备案-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
34 13
【03】仿站技术之python技术,看完学会再也不用去购买收费工具了-修改整体页面做好安卓下载发给客户-并且开始提交网站公安备案-作为APP下载落地页文娱产品一定要备案-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
|
4天前
|
数据采集 JavaScript Android开发
【02】仿站技术之python技术,看完学会再也不用去购买收费工具了-本次找了小影-感觉页面很好看-本次是爬取vue需要用到Puppeteer库用node.js扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
【02】仿站技术之python技术,看完学会再也不用去购买收费工具了-本次找了小影-感觉页面很好看-本次是爬取vue需要用到Puppeteer库用node.js扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
29 7
【02】仿站技术之python技术,看完学会再也不用去购买收费工具了-本次找了小影-感觉页面很好看-本次是爬取vue需要用到Puppeteer库用node.js扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
|
4天前
|
JavaScript 搜索推荐 Android开发
【01】仿站技术之python技术,看完学会再也不用去购买收费工具了-用python扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-客户的麻将软件需要下载落地页并且要做搜索引擎推广-本文用python语言快速开发爬取落地页下载-优雅草卓伊凡
【01】仿站技术之python技术,看完学会再也不用去购买收费工具了-用python扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-客户的麻将软件需要下载落地页并且要做搜索引擎推广-本文用python语言快速开发爬取落地页下载-优雅草卓伊凡
23 8
【01】仿站技术之python技术,看完学会再也不用去购买收费工具了-用python扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-客户的麻将软件需要下载落地页并且要做搜索引擎推广-本文用python语言快速开发爬取落地页下载-优雅草卓伊凡
|
1月前
|
测试技术 数据库 Python
Python装饰器实战:打造高效性能计时工具
在数据分析中,处理大规模数据时,分析代码性能至关重要。本文介绍如何使用Python装饰器实现性能计时工具,在不改变现有代码的基础上,方便快速地测试函数执行时间。该方法具有侵入性小、复用性强、灵活度高等优点,有助于快速发现性能瓶颈并优化代码。通过设置循环次数参数,可以更准确地评估函数的平均执行时间,提升开发效率。
106 61
Python装饰器实战:打造高效性能计时工具
|
1月前
|
数据可视化 算法 数据挖掘
Python时间序列分析工具Aeon使用指南
**Aeon** 是一个遵循 scikit-learn API 风格的开源 Python 库,专注于时间序列处理。它提供了分类、回归、聚类、预测建模和数据预处理等功能模块,支持多种算法和自定义距离度量。Aeon 活跃开发并持续更新至2024年,与 pandas 1.4.0 版本兼容,内置可视化工具,适合数据探索和基础分析任务。尽管在高级功能和性能优化方面有提升空间,但其简洁的 API 和完整的基础功能使其成为时间序列分析的有效工具。
80 37
Python时间序列分析工具Aeon使用指南
|
1月前
|
存储 算法 Serverless
剖析文件共享工具背后的Python哈希表算法奥秘
在数字化时代,文件共享工具不可或缺。哈希表算法通过将文件名或哈希值映射到存储位置,实现快速检索与高效管理。Python中的哈希表可用于创建简易文件索引,支持快速插入和查找文件路径。哈希表不仅提升了文件定位速度,还优化了存储管理和多节点数据一致性,确保文件共享工具高效运行,满足多用户并发需求,推动文件共享领域向更高效、便捷的方向发展。
|
2月前
|
数据可视化 编译器 Python
Manim:数学可视化的强大工具 | python小知识
Manim(Manim Community Edition)是由3Blue1Brown的Grant Sanderson开发的数学动画引擎,专为数学和科学可视化设计。它结合了Python的灵活性与LaTeX的精确性,支持多领域的内容展示,能生成清晰、精确的数学动画,广泛应用于教育视频制作。安装简单,入门容易,适合教育工作者和编程爱好者使用。
565 7
|
3月前
|
JavaScript 前端开发 开发者
探索 DrissionPage: 强大的Python网页自动化工具
DrissionPage 是一个基于 Python 的网页自动化工具,结合了浏览器自动化的便利性和 requests 库的高效率。它提供三种页面对象:ChromiumPage、WebPage 和 SessionPage,分别适用于不同的使用场景,帮助开发者高效完成网页自动化任务。
352 4
|
3月前
|
数据采集 JavaScript 程序员
探索CSDN博客数据:使用Python爬虫技术
本文介绍了如何利用Python的requests和pyquery库爬取CSDN博客数据,包括环境准备、代码解析及注意事项,适合初学者学习。
154 0
|
3月前
|
开发者 Python
探索Python中的列表推导式:简洁而强大的工具
【10月更文挑战第41天】 在编程的世界中,效率与简洁是永恒的追求。本文将深入探讨Python编程语言中一个独特且强大的特性——列表推导式(List Comprehension)。我们将通过实际代码示例,展示如何利用这一工具简化代码、提升性能,并解决常见编程问题。无论你是初学者还是资深开发者,掌握列表推导式都将使你的Python之旅更加顺畅。

热门文章

最新文章

推荐镜像

更多