Skip to content

【工具自荐】喜欢写作的朋友们,好消息来啦🎉🎉🎉!用artipub一键自动将文章发布至更多平台,让你的创作之旅更加畅快吧! #39

Open
@yxw007

Description

2

Artipub 是什么

ArtiPub(文章发布助手)是一个旨在简化内容创作者跨平台发布文章过程的工具库。它提供了一套简单的API,可以让你轻松地将文章发布到任意平台,如博客、Notion、Dev.to等,无需手动操作每个平台。artipub网站

❓ 为什么需要ArtiPub?

  1. markdown中引用的本地图片,需要手动压缩图片,然后上传至图床,最后在把图片链接替换掉
  2. markdown写完文章后,想发布至其他平台避免手动copy
  3. markdown写完文章后,我需要修改markdown中的一些内容,让其重新生成markdown内容
  4. ...

说明:ArtiPub全部帮你自动解决这些问题,未来将拓展更多内容

✨ 特点

  • 🌐 多平台发布:支持将markdown文章发布至任意内容平台(平台提供API),比如:Notion、Medium、Dev.to等。
  • 简单易用:提供了简洁的API,只需几行代码即可实现文章的发布。
  • 🔌 支持中间件和插件:通过插件和中间件,让用户更细粒度的控制处理和发布流程。
  • 📖 完全开源:鼓励社区贡献,持续增加新的平台支持和功能。

🔧 内置

处理中间件

名称 支持 描述
picCompress 图片自动压缩
picUpload 图片上传

发布插件

名称 支持 描述
NotionPublisherPlugin 发布至notion
DevToPublisherPlugin 发布至dev.to

🌟诞生背景

第一阶段:弃坑印象笔记,转用Notion

最开始我是使用印象笔记来记录笔记,随着时间的推移接触的东西越来越多,自然记录的笔记也越来越多,于是我想把笔记分类得更细,但是印象笔记分类最多三级,我在网上学习如何整理笔记,看了一些列的文章最终发现这种最多3级目录分类的方式,让我就用的特别不爽。
还有一个点就是固定"印象笔记"至开始屏幕,每次他们更新版本都把我的"印象笔记"图标从开始屏幕上搞丢了,我每次更新都要手动添加,这个也让我很不爽。给他们反馈过,但是他们的这个问题一直存在,我实在受不了,所以就在网络搜索各种笔记软件,最终发现Notion
非常好的满足我的需求,可以随意创建目录层级、文章管理非常方便、文章布局方式可以非常灵活的调整,这个软件非常适合我,所以我就把印象笔记的笔记全部迁移到了Notion上。

第二阶段:脱离notion孤岛,把知识分享出去

随着时间的推移我已是Notion的重度用户,导致我写的每个笔记or文章都先在Notion写完,我写了很多的笔记,我希望能把自己的知识分享出去,然后就想到把文章搞到自己blog、掘金、Medium、dev.to等平台,但这个过程非常繁琐,直接磨灭你写文章、分享知识的兴趣,
如果你文章是用中文写的,搞得自己的blog、国内平台还好,但是你要把文章搞得国外平台,这个过程就非常痛苦了,首先要把文章翻译,然后把里面的每张图片重新上传一遍,最让能抓狂的是Medium完全不支持copy markdown至它平台的编辑器,(使用了非常原始的编辑器,可能是平台特意设计如此来确保文章美观和质量),把markdown内容copy至
Medium编辑器后,文章格式全乱了,这个过程让我非常痛苦,如果你有过这样的经历,你肯定能体会到中间的痛苦,你可能会问:"既然Medium那么难用,你为啥还要把文章放到Medium上面,原因:它非常主流而且写文章还能获得收入,不像国内的各种平台..."

第三阶段:如何把notion上的文章分发出去呢?

我写了那么多笔记,如何把我掌握的知识分享出去呢?所以我在网上搜索notion to markdown,立马就找到了notion-to-md,此时就可以开心的把自己之前在notion上写的很多文章笔记转成markdown,然后发布至blog平台。搞下来后发现文章图片好像是临时图片地址,过一段时间后就图片就找不到了。这就让我有点头大,如果手动把notion上的文章下载下来,发现文章和图片都在一起,那么能不能写一个工具,把notion下载下来的zip文件,一键格式化成我blog文章格式不就可以了,于是我就添加了一些列处理函数,自动解压zip、自动压缩图片、自动上传图片、自动替换图片地址为cdn、自动提交和发布文章等功能,经过这一番操作后,那么我能不能做一个库用markdown来写文章,然后一键分发至任意平台呢?你可能会问:为什么不用notion写完文章后再通过工具分发至任意平台,当然这样也可以,只是多了在Notion写文章、然后下载文章和后续处理的步骤,所以在想为啥不直接用markdown来写文章,然后通过工具自动处理文章和资源,这个样更加灵活,于是就有了artipub这个文章发布助手。

🔍artipub 原型

ArticleProcessor

  • 输入:markdown草稿、图片资源
  • 处理过程:解析markdown、修改markdown内容、上传图片、替换图片地址等(此过程:要方便上层用户灵活修改markdown内容,所以立马就想到markdown AST,这样就可以方便的修改markdown内容)
  • 输出:将处理后的ast再转换markdown,存储至指定的地方即可

PublisherManager

  • 输入:markdown 文章内容
  • 处理过程:某些平台需要把特定文章部分内容去掉 or 提取特别部分内容(此过程:需要添加各种平台插件,方便把文章发布至各种平台)
  • 输出:将发布结果输出至控制台即可

补充说明:在正式开放之前,你可能会有各种纠结,产生一种幻想:要做一个最好最牛逼的工具,不停在自high中,不停的发散自己的思维... 特别注意:如果这种状态一直持续下去,你将什么事情的办不了,所以要及时收敛自己的思维,把自己的的初步想法落地,然后再不断的迭代,这样才能做出一个好的工具。今天看了一下Anthony 的开源之路:Yak Shaving「薅牛毛」,表示对这种状态深有体会,所以写下这段话告诫大家,及时收敛自己思维和注意力,让自己动手干起来。(曾经我也是这样的人啊)

💪撸起袖子干起来

第一阶段:实现第一个最基本的版本

提交记录

说明:第一个版本总共就10天,最主要还是周末写的多一点,平常工作日就搞一点点。

第二阶段:用在自己的blog项目上,不然怎么验证自己做的库可不可用,好不好用呢?

最开始我是直接通过发包至npm,然后在blog项目中使用,发现包有各种问题,就导致我发了很多坏的临时的包,如下图:
alt text

我就在想这样不是办法,第一个问题我的版本增长得太快了,第二个问题我发了这么多坏的包,对artipub使用者不负责,会对以后artipub的宣传带来不好的影响。

第一个问题的解决方案:我在网上搜了一大圈,有很多更新版本和生成changelog的库,最终还是没有选出用哪个库。偶然的在地铁上打开github看探索页面,看到版本发布。这时就想哪个库发版生成的changelog好看我就选哪个,最终发现changelogen简单好用,就选用了这个库。
alt text

第二个问题的解决方案:就想到在artipub项目中加一个playground,这样避免需要频繁发包,这样就可以在playground中测试artipub的各种功能,然后再把artipub的功能集成到blog项目中,这样为了避免掉发布很多坏的包。

第三阶段:把artipub集成到blog项目中

在集成artipub到blog项目中,立马就发现一个问题,blog还是用commonjs规范来写的代码,虽然artipub支持commonjs和esm 2种规范,但是引用库还是报不能引入esm模块,具体什么错误忘记了。我就在想esm已经是未来的趋势了,那么干脆直接把blog项目改成esm规范,避免乱七八糟的错误,但是当我改成esm规范后还是发现使用artipub 还是有各种问题。这就告诉我:无论你的库,本地测试没有问题,加了playground测试也没有问题,如果没有把库应用到真实的项目中,你永远不知道会出现什么问题,所以要及时把库应用到真实的项目中,这样才能发现问题,然后解决问题。

📊目前情况

  • [√] artipub已经集成至自己的blog项目中,验证可以正常使用了。
  • [√] artipub已有自己的文档网站,方便查看使用。aritpub传送门
  • 完善api文档
  • 添加测试用例
  • 支持发布文章至更多的平台

如果你对这项目感兴趣,帮忙点个star🌟,同时特别欢迎你的加入,让咋们一起完善这个项目,以使它帮助更多的人。😊

📝总结

  • 从一个想法到真实落地实现,中间经历了很多的坎坷,有想法、有灵感、有幻想,这些会让思维不停发散,最后要及时收敛自己的思维和注意力,把想法落地,然后再不断迭代,这样才可能做出你的工具。
  • Copilot 是一个非常好用的AI助手,个人感觉比其他各种助手好太多了,毕竟它有最好的模型训练数据github。过程中遇到各种问题,基本它都能辅助你解决,但是它也有它的局限性,比如:你要做一个功能,想法还不是很清晰,你可以不停的和它交流,让你的想法形成初稿然后落地下来的这个过程还是很有帮助的。起初我用9.9美元试用了一个月,后来发现非常好用,而且这钱花的非常值,就立马切换成按年订阅了,推荐大家试试 GitHub Copilot

📚参考资料

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions