🚀用脚本助力博客搬家

简介: 🚀用脚本助力博客搬家

image.png

前言

由于某书慢慢变的热门推荐文章标题诡异,内容垃圾,登录麻烦等问题,又由于掘金社区的慢慢壮大,后来就慢慢写文章就主要在掘金社区了,但是在简书上写了好几年的笔记和文章,掘金到目前为止还不支持简书文章直接自动搬运,好在支持通过 Markdown 文件导入的方式搬运,由于之前已经通过脚本下载好了(用js脚本下载某书的所有文章),直接把本地的文章 Markdown 文件导入就行了,没想到,这只是个开始,本地导入后无法直接在线修改文章名称

下载到本地的文章

由于简书是 文集 的方式进行文章的分类,我用脚本下载后文章名称加了一个 文集 并用 - 进行拼接,方便本地浏览分类


image.png


选择文件后如下效果


image.png

发现无法修改要发布文章的名称,手动删除 文集 名称和 - 后发布会把 《》 也带上去,然后根据 文集 类型手动改了一个 文集 中的所有文章,发现手改太痛苦了,由于本地文章和未发布的笔记超过两三百篇,这次要搬运的文章两百多篇,手改好两百个文件名再手动拖上去选择分类和标签岂不是要改死了,要不写个 node 脚本处理一下?

脚本实现的目标

运行脚本,脚本读取某个目录下的 Markdown 文件,然后修改文件名,根据 -《》 来判断,得到导入后发布的文章名称

开始实现

初始化node项目

建立一个 server.js 文件,在同级目录下控制台中执行 npm init 命令,默认一直敲回车 node 项目就初始化好了


image.png


先建一个 test-file 文件,里面放几个 Markdown 文件用来做测试


image.png

安装 pathfs 模块,path 用来读取文件路径, fs 用来修改文件

npm i path fs -D

获取路径

引入 path 模块,使用 path.join 获取 test-file 文件夹路径

const path = require("path");
const url = path.join('C:', 'Users', 'qingy', 'Desktop', '新建文件夹', 'script', 'test-file');
console.log('url: ', url)

image.png

读取路径下的文件并分割

使用 fs.readdir 读取路径下的所有文件,获取文件列表后,循环处理文件,先是将 - 分割文件得到带 《》 文件名的名称数组,再单独分割 就得到了要发布的文章名称,使用 fs.rename 修改原文件名称,这里要注意文件路径的拼接,由于整体逻辑具有关联性,直接把整段代码贴了出来,在代码对应的地方添加注释方便理解,如下

fs.readdir(url, "utf8", (err, fileList) => {
  if (err) throw err;
  console.log(fileList);
  fileList.forEach((item, index) => {
    console.log("index: " + index);
    console.log(item);
    // 第一次分割,得到带《》的文件名称数组
    const arr = item.split(" - ");
    if (arr.length > 1) {
      console.log("arr", arr);
      // 第二次分割《》,得到文章名称和文件后缀名
      const nameArr = arr[1].split("《")[1].split("》");
      console.log("nameArr: ", nameArr);
      // 拼接得到掘金自动导入的文件名称效果
      const fileName = nameArr[0] + nameArr[1];
      console.log("fileName: ", fileName);
      // 更新文件名称
      const old = url + "\\" + item;
      console.log("old: " + old);
      const newName = url + "\\" + fileName;
      console.log("new: ", newName);
      fs.rename(url + "\\" + item, url + "\\" + fileName, (err) => {
        throw err;
      });
    } else {
      console.log("文件名称不符合预期格式");
    }
  });
});

脚本写完后,执行如下命名运行脚本

node server.js

执行脚本后,文件名的效果

image.png


到这里脚本就已经把该做的都做完了,剩下的就是按文集分类导入,这样可以统一选择文章类型和标签

完整代码链接

github.com/gywgithub/F…

文章导入文件失败

在实际操作中发现,如果是一次选择了多篇文章,点击 导入并发布 按钮会出现导入成功 x 篇,失败 x 篇的情况,这部分可能是导入工具的实现没有做相应的优化,继续点击 导入并发布 按钮导入就可以了


image.png

扩展

由于自己日常前端开发为主,node 相关的稍微熟悉一点,脚本以实现目的为主,也有其他的更优雅的实现和思路;关于博客搬家,还有一个 官方协助导入发布,有 JYM 用过这个功能吗?体验如何呢?

image.png

目录
相关文章
|
8月前
|
数据采集 机器学习/深度学习 算法
自学Python的最佳实践!
自学Python的最佳实践!
133 0
|
3月前
|
存储 JavaScript 前端开发
🚀超级加速:轻松发现开源项目的终极秘籍🎁
本文介绍了8种方法,帮助开发者轻松找到适合自己的开源项目。通过利用如 GitHub Trending、Good First Issues 和 OpenSauced 等平台,读者可以有效地筛选和参与开源项目,提升自己的技术能力与社交网络。开源不仅是技术贡献,更是个人成长与机会的宝贵途径。无论是新手还是有经验的开发者,这些资源都能助你一臂之力,让你在开源社区中茁壮成长。
27 1
|
5月前
|
API Python
🚀一键启动创意引擎!生成式大模型提示词工程,让你的想象触手可及🚀
【8月更文挑战第1天】在数字时代,生成式大模型正重塑内容创作边界。提示词如同创意钥匙,通过明确主题、构建场景、设定角色与情节、添加风格情感等步骤,能激发模型生成所需内容。示例代码展示了从提示词到生成内容的过程。通过提示词工程,我们可以一键启动创意引擎,将想象变为现实,开启无限创意可能。
90 8
|
5月前
|
人工智能 自然语言处理
🚀从菜鸟到大师,一文读懂生成式大模型“提示词工程”的进阶秘籍✨
【8月更文挑战第1天】在人工智能领域,生成式大模型如GPT和DALL-E正引领着创意的新纪元。本文通过案例逐步解析“提示词工程”的精髓:从基础的直接提示,进化到富含细节与情感的进阶版本,再到结合模板与随机性的大师级应用。例如,创作环保主题文章时,从简单指示到强调个人行动与自然之美;生成印象派风格的日出海景图时,详述光线、色彩等元素。随着技巧提升,还可利用基础模板加随机提示的方式确保创意与质量并重。掌握这些秘籍,你也能驾驭AI,释放无限可能。
121 7
|
8月前
|
前端开发 JavaScript
🚀用脚本助力博客搬家
🚀用脚本助力博客搬家
80 0
|
7月前
|
JSON 程序员 Swift
技术好文:Swit项目
技术好文:Swit项目
36 0
|
8月前
|
编译器 C语言 C++
【C++初阶】第一站:C++入门基础(上) -- 良心详解-2
【C++初阶】第一站:C++入门基础(上) -- 良心详解-2
|
8月前
|
安全 Unix 编译器
【C++初阶】第一站:C++入门基础(上) -- 良心详解-1
【C++初阶】第一站:C++入门基础(上) -- 良心详解-1
|
编译器 C++
《C++避坑神器·八》史上最全模板的使用
《C++避坑神器·八》史上最全模板的使用
58 0
|
前端开发
带你读书之“红宝书”:第三章 语法基础(上)之 关键词后续
带你读书之“红宝书”:第三章 语法基础(上)之 关键词后续
107 0
带你读书之“红宝书”:第三章 语法基础(上)之 关键词后续