🚀用脚本助力博客搬家

前言

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

下载到本地的文章

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

选择文件后如下效果

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

脚本实现的目标

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

开始实现

初始化node项目

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

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

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

js 复制代码
npm i path fs -D

获取路径

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

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

读取路径下的文件并分割

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

js 复制代码
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("文件名称不符合预期格式");
    }
  });
});

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

bash 复制代码
node server.js

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

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

完整代码链接

github.com/gywgithub/F...

文章导入文件失败

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

扩展

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

欢迎大家讨论交流,如果文章感觉有用,随手点个赞再走呗 ^_^ 🥰🥰

微信公众号:草帽Lufei

相关推荐
一 乐6 小时前
婚纱摄影网站|基于ssm + vue婚纱摄影网站系统(源码+数据库+文档)
前端·javascript·数据库·vue.js·spring boot·后端
C_心欲无痕7 小时前
ts - tsconfig.json配置讲解
linux·前端·ubuntu·typescript·json
清沫7 小时前
Claude Skills:Agent 能力扩展的新范式
前端·ai编程
yinuo7 小时前
前端跨页面通信终极指南:方案拆解、对比分析
前端
yinuo8 小时前
前端跨页面通讯终极指南⑨:IndexedDB 用法全解析
前端
xkxnq8 小时前
第二阶段:Vue 组件化开发(第 16天)
前端·javascript·vue.js
烛阴8 小时前
拒绝配置地狱!5 分钟搭建 Three.js + Parcel 完美开发环境
前端·webgl·three.js
xkxnq9 小时前
第一阶段:Vue 基础入门(第 15天)
前端·javascript·vue.js
anyup10 小时前
2026第一站:分享我在高德大赛现场学到的技术、产品与心得
前端·架构·harmonyos
BBBBBAAAAAi10 小时前
Claude Code安装记录
开发语言·前端·javascript