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

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

infoq的博客发布界面也是非常简洁的。首页就只有基本的标题,内容和封面图片,所以infoq的实现也相对比较简单。

一起来看看吧。

前提条件

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

infoq的实现

接下来我会带领大家一步步实现infoq的博客自动发布。

上传封面

infoq的上传封面底层是一个input标签:

image-20240507210315786

这个是可以通过selenium来实现的。

我们先找到这个input标签,然后调用send_keys即可实现图片的上传:

    # 上传封面
        if 'image' in front_matter and front_matter['image']:
                file_input = driver.find_element(By.XPATH, "//input[@type='file']")
                        # 文件上传不支持远程文件上传,所以需要把图片下载到本地
                                file_input.send_keys(download_image(front_matter['image']))
                                        time.sleep(2)
                                    这里要注意的是,要上传的封面是放在markdown的最上面yaml front matter里面的。

                                    如图所示:

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



                                    另外要注意的是,因为博客的上传功能只支持本地上传,所以如果你的image是远程地址的话,需要先把远程图片现在到本地,然后再用本地图片来上传。

                                    下载图片到本地的代码这里就不写了。

                                    感兴趣的朋友可以直接去看我的代码。

                                    ### 文章标题

                                    infoq的文章标题没有ID,这样的话我们就需要通过xpath来定位文章标题。

                                    一般来说标题的地方都有placeholder,所以我们可以通过xpath来定位到标题:

                                    ```python
                                        # 文章标题
                                            title = driver.find_element(By.XPATH, '//input[@placeholder="请输入标题"]')
                                                title.clear()
                                                    if 'title' in front_matter['title'] and front_matter['title']:
                                                            title.send_keys(front_matter['title'])
                                                                else:
                                                                        title.send_keys(common_config['title'])
                                                                            time.sleep(2)  # 等待3秒
                                                                            ```

                                                                            ### 文章内容

                                                                            之前有提到segmentfault和oschina用的是codemirror,而infoq用的是ProseMirror。

                                                                            这种动态富文本编辑器会根据你的输入动态修改html内容。所以没办法像textArea那样直接获取元素之后设置他的内容。

                                                                            这里我们只能采用拷贝粘贴的方式来设置。

                                                                            怎么定位到文章内容框呢?

                                                                            因为我们现在刚刚输入完文章标题。所以只需要输入两次tab键就可以把鼠标定位到文章内容输入框了。

                                                                            所以,我们的代码如下:

                                                                            ```python
                                                                            # 文章内容 markdown版本
                                                                                file_content = read_file_with_footer(common_config['content'])
                                                                                    # 用的是CodeMirror,不能用元素赋值的方法,所以我们使用拷贝的方法
                                                                                        cmd_ctrl = Keys.COMMAND if sys.platform == 'darwin' else Keys.CONTROL
                                                                                            # 将要粘贴的文本内容复制到剪贴板
                                                                                                pyperclip.copy(file_content)
                                                                                                    action_chains = webdriver.ActionChains(driver)
                                                                                                        # tab
                                                                                                            action_chains.key_down(Keys.TAB).key_up(Keys.TAB).perform()
                                                                                                                time.sleep(2)
                                                                                                                    # 模拟实际的粘贴操作
                                                                                                                        action_chains.key_down(cmd_ctrl).send_keys('v').key_up(cmd_ctrl).perform()
                                                                                                                            time.sleep(3)  # 等待3秒
                                                                                                                            ```

                                                                                                                            ### 点发布文章按钮

                                                                                                                            点击发布文章按钮,这个比较简单,直接根据class的名字获取到对应的元素即可:

                                                                                                                            ```python
                                                                                                                                # 发布文章
                                                                                                                                    send_button = driver.find_element(By.XPATH, '//div[contains(@class, "submit-btn")]')
                                                                                                                                        send_button.click()
                                                                                                                                            time.sleep(2)
                                                                                                                                            ```

                                                                                                                                            ### 设置摘要

                                                                                                                                            点完发布文章按钮,会出现一个弹出框,在弹出框里面可以设置摘要和标签等信息。

                                                                                                                                            摘要部分是一个textarea,我们可以通过xpath的方式定位到它:

                                                                                                                                            ```python
                                                                                                                                                if summary:
                                                                                                                                                        summary_input = driver.find_element(By.XPATH, '//div[@class="summary"]/textarea')
                                                                                                                                                                summary_input.clear()
                                                                                                                                                                        summary_input.send_keys(summary)
                                                                                                                                                                            time.sleep(2)
                                                                                                                                                                            ```

                                                                                                                                                                            ### 设置标签

                                                                                                                                                                            标签是一个input,这里我们也是通过xpath来定位:

                                                                                                                                                                            ```python
                                                                                                                                                                                if tags:
                                                                                                                                                                                        for tag in tags:
                                                                                                                                                                                                    tag_input = driver.find_element(By.XPATH, '//div[@class="search-tag"]//input')
                                                                                                                                                                                                                tag_input.send_keys(tag)
                                                                                                                                                                                                                            time.sleep(1)
                                                                                                                                                                                                                                        tag_input.send_keys(Keys.ENTER)
                                                                                                                                                                                                                                        ```

                                                                                                                                                                                                                                        在设置标签的过程中,每设置完成一个,我们就按一下回车,接下来就可以设置下一个标签了。

                                                                                                                                                                                                                                        非常的方便。

                                                                                                                                                                                                                                        ### 最后的提交

                                                                                                                                                                                                                                        最后的最后,我们就可以真正的点击提交按钮了。

                                                                                                                                                                                                                                        ```python
                                                                                                                                                                                                                                            if auto_publish:
                                                                                                                                                                                                                                                    publish_button = driver.find_element(By.XPATH, '//div[@class="dialog-footer-buttons"]/div[contains(text(),"确定")]')
                                                                                                                                                                                                                                                            publish_button.click()
                                                                                                                                                                                                                                                            ```

                                                                                                                                                                                                                                                            这个提交按钮不是很好定位,我们只能通过div的class和text来找到提交按钮。

                                                                                                                                                                                                                                                            ## 总结

                                                                                                                                                                                                                                                            infoq的界面看起来比较简单,但是实现过程中还是有一些要注意的事项。



                                                                                                                                                                                                                                                            大家在实现的过程中需要留意。

                                                                                                                                                                                                                                                            [点我查看更多精彩内容:www.flydean.com](www.flydean.com)
相关文章
|
2月前
|
运维 Linux Apache
Puppet 作为一款强大的自动化运维工具,被广泛应用于配置管理领域。通过定义资源的状态和关系,Puppet 能够确保系统始终处于期望的配置状态。
Puppet 作为一款强大的自动化运维工具,被广泛应用于配置管理领域。通过定义资源的状态和关系,Puppet 能够确保系统始终处于期望的配置状态。
62 3
|
17天前
|
安全 前端开发 测试技术
如何选择合适的自动化安全测试工具
选择合适的自动化安全测试工具需考虑多个因素,包括项目需求、测试目标、系统类型和技术栈,工具的功能特性、市场评价、成本和许可,以及集成性、误报率、社区支持、易用性和安全性。综合评估这些因素,可确保所选工具满足项目需求和团队能力。
|
18天前
|
运维 Ubuntu 应用服务中间件
自动化运维工具Ansible的实战应用
【10月更文挑战第36天】在现代IT基础设施管理中,自动化运维已成为提升效率、减少人为错误的关键手段。本文通过介绍Ansible这一流行的自动化工具,旨在揭示其在简化日常运维任务中的实际应用价值。文章将围绕Ansible的核心概念、安装配置以及具体使用案例展开,帮助读者构建起自动化运维的初步认识,并激发对更深入内容的学习兴趣。
41 4
|
20天前
|
运维 监控 数据安全/隐私保护
自动化运维工具的设计与实现
【10月更文挑战第34天】在现代IT基础设施管理中,自动化运维工具扮演着至关重要的角色。它们不仅提高了运维效率,还确保了服务的连续性和稳定性。本文将深入探讨如何设计并实现一个自动化运维工具,从需求分析到功能实现,再到最终的测试与部署。我们将通过一个简单的代码示例来展示如何自动执行常见的运维任务,如日志清理和性能监控。文章旨在为读者提供一套完整的方法论,以便他们能够构建自己的自动化运维解决方案。
|
2月前
|
运维 关系型数据库 MySQL
自动化运维工具Ansible的实战应用
【10月更文挑战第9天】在现代IT运维领域,效率和可靠性是衡量一个系统是否健康的重要指标。自动化运维工具Ansible因其简洁、易用的特性,成为了众多企业和开发者的首选。本文将通过实际案例,展示如何利用Ansible进行日常的运维任务,包括配置管理、软件部署以及批量操作等,帮助读者深入理解Ansible的应用场景及其带来的效益。
|
2月前
|
人工智能 运维 监控
自动化运维:从脚本到工具的演变之路
【10月更文挑战第8天】在数字化时代的浪潮中,运维不再是简单的硬件维护,它已经演变成一场关于效率、稳定性和创新的技术革命。本文将带您领略自动化运维的魅力,从最初的脚本编写到现代复杂的自动化工具,我们将一探究竟,看看这些工具如何帮助运维人员简化日常任务,提升工作效率,并最终推动业务发展。
|
2月前
|
JavaScript 前端开发 搜索推荐
Gulp:构建自动化与任务管理的强大工具
【10月更文挑战第13天】Gulp:构建自动化与任务管理的强大工具
77 0
|
2月前
|
机器学习/深度学习 人工智能 运维
构建高效运维体系:从自动化到智能化的演进
本文探讨了如何通过自动化和智能化手段,提升IT运维效率与质量。首先介绍了自动化在简化操作、减少错误中的作用;然后阐述了智能化技术如AI在预测故障、优化资源中的应用;最后讨论了如何构建一个既自动化又智能的运维体系,以实现高效、稳定和安全的IT环境。
68 4
|
2月前
|
运维 Linux Apache
,自动化运维成为现代IT基础设施的关键部分。Puppet是一款强大的自动化运维工具
【10月更文挑战第7天】随着云计算和容器化技术的发展,自动化运维成为现代IT基础设施的关键部分。Puppet是一款强大的自动化运维工具,通过定义资源状态和关系,确保系统始终处于期望配置状态。本文介绍Puppet的基本概念、安装配置及使用示例,帮助读者快速掌握Puppet,实现高效自动化运维。
57 4
|
16天前
|
机器学习/深度学习 数据采集 人工智能
智能运维:从自动化到AIOps的演进与实践####
本文探讨了智能运维(AIOps)的兴起背景、核心组件及其在现代IT运维中的应用。通过对比传统运维模式,阐述了AIOps如何利用机器学习、大数据分析等技术,实现故障预测、根因分析、自动化修复等功能,从而提升系统稳定性和运维效率。文章还深入分析了实施AIOps面临的挑战与解决方案,并展望了其未来发展趋势。 ####