一键自动化博客发布工具,用过的人都说好(segmentfault篇)

简介: 使用一键自动化博客发布工具blog-auto-publishing-tools把博客发布到segmentfault上。

segmentfault是我在这些平台中看过界面最为简洁的博客平台了。

今天就以segmentfault为例,讲讲在blog-auto-publishing-tools中的实现原理。

前提条件

前提条件当然是先下载 blog-auto-publishing-tools这个博客自动发布工具,地址如下:https://github.com/ddean2009/blog-auto-publishing-tools

segmentfault的实现

接下来我们手把手看看具体在segmentfault的自动化是如何实现的。

segmentfault的配置文件

在config目录下面,你会找到一个segmentfault.yaml的文件,这个就是segmentfault的配置文件了。

内容很简单,如下所示:

site: https://segmentfault.com/write

tags:
  - 人工智能
    - aigc
      - openai
        - ai开发
    里面主要是两个内容,site是segmentfault的博客编写页面。

    tags是你的博客的一些标签,可以自行设置。

    > 这里要注意的是,segmentfault中的标签并不能随意写,你需要选择segmentfault中已有的标签才可以。

    ### segmentfault的实现逻辑

    所有的发布器都在publisher目录下,在下面你可以找到segmentfault_publisher这个专门给segmentfault的发布器。

    首先我们需要打开新的tab,然后切换到segmentfault的博客发布页面:

    ```python
        # 打开新标签页并切换到新标签页
            driver.switch_to.new_window('tab')
                # 浏览器实例现在可以被重用,进行你的自动化操作
                    driver.get(segmentfault_config['site'])
                        time.sleep(2)  # 等待2秒
                        ```

                        ### 处理标题

                        进入发布页面,我们看看页面的一些结构,首先是标题。

                        标题比较简单,自带了ID:

                        ![image-20240506104029630](https://flydean-1301049335.cos.ap-guangzhou.myqcloud.com/img/202405061040404.png)

                        所以我们可以直接使用find_element by ID直接获得title的input,然后调用send_keys方法,把title的内容输入进去。

                        如下所示:

                        ```python
                            # 文章标题
                                title = driver.find_element(By.ID, 'title')
                                    title.clear()
                                        title.send_keys(common_config['title'])
                                            time.sleep(2)  # 等待3秒
                                            ```

                                            ### 处理内容

                                            接下来我们看看内容这一块。如果进入调试模式,你会看到segmentfault的内容部分不是一个简单的textarea,而是使用了CodeMirror这个开源的在线代码编辑工具。

                                            ![image-20240506104412339](https://flydean-1301049335.cos.ap-guangzhou.myqcloud.com/img/202405061044973.png)

                                            这个CodeMirror的代码内容是会随着你的输入不断进行变化的。

                                            那么我们怎么才能把鼠标定位到CodeMirror的代码块中进行内容输入呢?

                                            这里我们有一个小技巧。

                                            如果你进入segmentfault写博客的首页,你会发现鼠标默认是定位在『请输入标题』这个标题栏的部分。

                                            接下来如果我们连续输入三次tab键,鼠标就会定位到CodeMirror内容编辑框了。

                                            然后我们只需要使用复制粘贴功能,把markdown的内容粘贴到内容框即可完成内容的输入。

                                            以下是代码实现:

                                            ```python
                                                # 文章内容
                                                    file_content = read_file_with_footer(common_config['content'])
                                                        # segmentfault比较特殊,用的是CodeMirror,不能用元素赋值的方法,所以我们使用拷贝的方法
                                                            cmd_ctrl = Keys.COMMAND if sys.platform == 'darwin' else Keys.CONTROL
                                                                # 将要粘贴的文本内容复制到剪贴板
                                                                    pyperclip.copy(file_content)
                                                                        # 三次tab按钮,让光标定位到内容窗口:
                                                                            action_chains = webdriver.ActionChains(driver)
                                                                                for i in range(3):
                                                                                        action_chains.key_down(Keys.TAB).key_up(Keys.TAB).perform()
                                                                                                time.sleep(1)

                                                                                                    # 模拟实际的粘贴操作
                                                                                                        action_chains.key_down(cmd_ctrl).send_keys('v').key_up(cmd_ctrl).perform()
                                                                                                            time.sleep(3)  # 等待3秒
                                                                                                            ```

                                                                                                            实际上在操作中,你会发现使用tab键定位之后,拷贝是拷贝不进去的。

                                                                                                            所以上面的方法其实是不可行的。我们仍然需要定位到文章内容部分.....

                                                                                                            我们仔细看看内容编辑部分,可以看到在CodeMirror-code下面有一个span的role=presentation,就它了,我们使用xpath来定位,代码如下所示:

                                                                                                            ```python
                                                                                                             # 文章内容
                                                                                                                file_content = read_file_with_footer(common_config['content'])
                                                                                                                    # segmentfault比较特殊,用的是CodeMirror,不能用元素赋值的方法,所以我们使用拷贝的方法
                                                                                                                        cmd_ctrl = Keys.COMMAND if sys.platform == 'darwin' else Keys.CONTROL
                                                                                                                            # 将要粘贴的文本内容复制到剪贴板
                                                                                                                                pyperclip.copy(file_content)
                                                                                                                                    action_chains = webdriver.ActionChains(driver)
                                                                                                                                        # 三次tab按钮,让光标定位到内容窗口:
                                                                                                                                            for i in range(3):
                                                                                                                                                    action_chains.key_down(Keys.TAB).key_up(Keys.TAB).perform()
                                                                                                                                                            time.sleep(1)

                                                                                                                                                                # 找到初始的内容描述文字
                                                                                                                                                                    content = driver.find_element(By.XPATH, '//div[@class="CodeMirror-code"]//span[@role="presentation"]')
                                                                                                                                                                        content.click()
                                                                                                                                                                            # 模拟实际的粘贴操作
                                                                                                                                                                                action_chains.key_down(cmd_ctrl).send_keys('v').key_up(cmd_ctrl).perform()
                                                                                                                                                                                    time.sleep(3)  # 等待3秒
                                                                                                                                                                                    ```

                                                                                                                                                                                    ### 处理标签

                                                                                                                                                                                    标题,内容都有了,接下来就是标签处理了。

                                                                                                                                                                                    ![image-20240506110505887](https://flydean-1301049335.cos.ap-guangzhou.myqcloud.com/img/202405061105856.png)

                                                                                                                                                                                    segmentfault的标签处理逻辑:

                                                                                                                                                                                    1. 点击添加标签按钮
    1. 在搜索标签框输入要添加的标签
    1. 回车即可。
    1. 如果有多个标签,重复2-3这两步。
      所以我们可以得到下面的代码:
    # 添加标签
        tag_button = driver.find_element(By.ID, 'tags-toggle')
            tag_button.click()
                tag_input = driver.find_element(By.XPATH, '//input[@placeholder="搜索标签"]')
                    for tag in segmentfault_config['tags']:
                            tag_input.send_keys(tag)
                                    tag_input.send_keys(Keys.ENTER)
                                            time.sleep(2)
                                                time.sleep(2)
                                            ### 点击发布文章按钮

                                            点击发布文章按钮之后,会有一个下拉弹窗框,让你选择封面,文章类型,发布到,定时发布和注明版权这些东西。

                                            发布文章按钮很简单,直接根据ID查找即可:

                                            ```python
                                                # 发布按钮
                                                    publish_button = driver.find_element(By.ID, 'publish-toggle')
                                                        publish_button.click()
                                                            time.sleep(2)
                                                            ```

                                                            ### 设置封面

                                                            正常情况下设置封面需要点击设置封面按钮,然后从本地选择一个封面图片上传。

                                                            这样就比较麻烦了。我们直接从markdown的front matter中读取imge的地址,上传到网站上。

                                                            事实上,除了image之外,title,tags,description 都会优先从markdown的front matter中去会获取。这样就不用每次去修改配置文件了。

                                                            ```yaml
                                                            title: 一键自动化博客发布工具,用过的人都说好(segmentfault篇)
                                                            authors: flydean
                                                            tags: [自动化工具,博客,自动发布]
                                                            image: https://flydean-1301049335.cos.ap-guangzhou.myqcloud.com/img/202405061040404.png
                                                            description: 使用一键自动化博客发布工具blog-auto-publishing-tools把博客发布到segmentfault上。
                                                            ```

                                                            上传封面的代码如下:

                                                            ```python
                                                                # 设置封面
                                                                    if front_matter['image']:
                                                                            file_input = driver.find_element(By.XPATH, "//input[type='file']")
                                                                                    file_input.send_keys(front_matter['image'])
                                                                                            time.sleep(2)
                                                                                            ```

                                                                                            ### 设置版权

                                                                                            ```python
                                                                                                # 版权
                                                                                                    copy_right = driver.find_element(By.ID, 'license')
                                                                                                        copy_right.click()
                                                                                                            time.sleep(2)
                                                                                                            ```

                                                                                                            版权设置比较简单,直接找到对应的ID即可。

                                                                                                            ### 最终发布

                                                                                                            最后找到发布按钮就可以发布了。

                                                                                                            ```python
                                                                                                                # 确认发布
                                                                                                                    if auto_publish:
                                                                                                                            confirm_button = driver.find_element(By.ID, 'sureSubmitBtn')
                                                                                                                                    confirm_button.click()
                                                                                                                                    ```


                                                                                                                                    [点我查看更多精彩内容:www.flydean.com](www.flydean.com)
相关文章
|
20天前
|
Java 测试技术 数据安全/隐私保护
软件测试中的自动化策略与工具应用
在软件开发的快速迭代中,自动化测试以其高效、稳定的特点成为了质量保证的重要手段。本文将深入探讨自动化测试的核心概念、常见工具的应用,以及如何设计有效的自动化测试策略,旨在为读者提供一套完整的自动化测试解决方案,帮助团队提升测试效率和软件质量。
|
13天前
|
Web App开发 IDE 测试技术
Selenium:强大的 Web 自动化测试工具
Selenium 是一款强大的 Web 自动化测试工具,包括 Selenium IDE、WebDriver 和 Grid 三大组件,支持多种编程语言和跨平台操作。它能有效提高测试效率,解决跨浏览器兼容性问题,进行性能测试和数据驱动测试,尽管存在学习曲线较陡、不稳定等缺点,但其优势明显,是自动化测试领域的首选工具。
94 17
Selenium:强大的 Web 自动化测试工具
|
18天前
|
运维 Kubernetes Devops
自动化运维:从脚本到工具的演进之旅
在数字化浪潮中,自动化运维成为提升效率、保障系统稳定的关键。本文将探索自动化运维的发展脉络,从基础的Shell脚本编写到复杂的自动化工具应用,揭示这一技术变革如何重塑IT运维领域。我们将通过实际案例,展示自动化运维在简化工作流程、提高响应速度和降低人为错误中的重要作用。无论你是初学者还是资深专家,这篇文章都将为你提供宝贵的洞见和实用的技巧。
|
28天前
|
机器学习/深度学习 人工智能 运维
自动化运维之路:从脚本到工具的演进
在IT运维领域,效率和准确性是衡量工作成效的关键指标。随着技术的发展,自动化运维逐渐成为提升这两个指标的重要手段。本文将带领读者了解自动化运维的演变历程,从最初的简单脚本编写到现今复杂的自动化工具应用,展示如何通过技术提升运维效率。文章不仅介绍理论和实践案例,还提供了代码示例,帮助读者理解自动化运维的实际应用场景。
|
1月前
|
JavaScript 前端开发 开发者
探索 DrissionPage: 强大的Python网页自动化工具
DrissionPage 是一个基于 Python 的网页自动化工具,结合了浏览器自动化的便利性和 requests 库的高效率。它提供三种页面对象:ChromiumPage、WebPage 和 SessionPage,分别适用于不同的使用场景,帮助开发者高效完成网页自动化任务。
129 4
|
1月前
|
安全 前端开发 测试技术
如何选择合适的自动化安全测试工具
选择合适的自动化安全测试工具需考虑多个因素,包括项目需求、测试目标、系统类型和技术栈,工具的功能特性、市场评价、成本和许可,以及集成性、误报率、社区支持、易用性和安全性。综合评估这些因素,可确保所选工具满足项目需求和团队能力。
|
1月前
|
运维 Ubuntu 应用服务中间件
自动化运维工具Ansible的实战应用
【10月更文挑战第36天】在现代IT基础设施管理中,自动化运维已成为提升效率、减少人为错误的关键手段。本文通过介绍Ansible这一流行的自动化工具,旨在揭示其在简化日常运维任务中的实际应用价值。文章将围绕Ansible的核心概念、安装配置以及具体使用案例展开,帮助读者构建起自动化运维的初步认识,并激发对更深入内容的学习兴趣。
57 4
|
2月前
|
机器学习/深度学习 人工智能 运维
构建高效运维体系:从自动化到智能化的演进
本文探讨了如何通过自动化和智能化手段,提升IT运维效率与质量。首先介绍了自动化在简化操作、减少错误中的作用;然后阐述了智能化技术如AI在预测故障、优化资源中的应用;最后讨论了如何构建一个既自动化又智能的运维体系,以实现高效、稳定和安全的IT环境。
77 4
|
2月前
|
运维 Linux Apache
,自动化运维成为现代IT基础设施的关键部分。Puppet是一款强大的自动化运维工具
【10月更文挑战第7天】随着云计算和容器化技术的发展,自动化运维成为现代IT基础设施的关键部分。Puppet是一款强大的自动化运维工具,通过定义资源状态和关系,确保系统始终处于期望配置状态。本文介绍Puppet的基本概念、安装配置及使用示例,帮助读者快速掌握Puppet,实现高效自动化运维。
65 4
|
23天前
|
机器学习/深度学习 运维 监控
智能化运维:从自动化到AIOps的演进之路####
本文深入探讨了IT运维领域如何由传统手工操作逐步迈向高度自动化,并进一步向智能化运维(AIOps)转型的过程。不同于常规摘要仅概述内容要点,本摘要将直接引入一个核心观点:随着云计算、大数据及人工智能技术的飞速发展,智能化运维已成为提升企业IT系统稳定性与效率的关键驱动力。文章详细阐述了自动化工具的应用现状、面临的挑战以及AIOps如何通过预测性分析和智能决策支持,实现运维工作的质变,引领读者思考未来运维模式的发展趋势。 ####
下一篇
DataWorks