20分钟用ChatGPT开发一个参考文献自动编号应用

背景介绍

又到了一年一度的毕业论文答辩季,相信很多人都在整理论文参考文献时都遇到过类似的场景:

假设你的论文现在有五十篇的参考文献,已经编号完成了。老师看完论文之后要求你再补充一些内容,于是你又多引用了一篇文献,但因为参考文献必须按顺序排列,所以你只能从中间插入这篇文献。假设这篇文献的位置应该是第17,那也就意味着从第17篇开始的参考文献序号都得加1。而Word又不像VSCode或者vim,可以实现快速的数字修改,所以只能苦逼地手动修改34篇文献的序号。

[1] 段宇锋, 黄思思. 本体构建方法研究[J]. 情报杂志, 2015, 34(11): 139-144.
...
[15] 贾君枝, 牛雅楠. 本体评估工具的比较分析[J]. 图书情报工作, 2010, 54(6): 87-90.
[16] 徐雷. 本体评估研究进展[J]. 情报学报, 2016, 35(7): 772-784.

// 如果我想在这里增加一篇,那么后面的从17-50的文献编号就得改成18-51,要改34个数字!

[17] 徐增林, 盛泳潘, 贺丽荣, 等. 知识图谱技术综述[J]. 电子科技大学学报, 2016, 45(04): 589-606.
...
[50] 李兴森, 石勇, 张玲玲. 从信息爆炸到智能知识管理[M]. 科学出 版社. 2010:49-62.

我在写论文的过程中就遇到了这样的问题,因为觉得实在是太麻烦了,就想着能不能写一个程序来自动化地完成这个重新编号的任务。于是我就新建了一个 js 文件打算试一试,结果发现其实并不复杂,只要几行代码就可以做到了。下面就来讲讲具体的思路。

序号自动生成

输入输出分析

程序的输入是一个长字符串,也就是我从word文档里面复制过来的一整个参考文献列表。每一条参考文献条目由换行符分隔。

程序的输出同样应该是一个长字符串,形式与输入类似,这样我才能直接粘贴回word里面。输出与输入的区别在于输出中每一个参考文献条目的序号是正确的。

核心算法开发

因为我们要对每一条参考文献条目都做单独的处理,所以首先应该把读取进来的长字符串分割为一个数组,数组中的每一项对应一条参考文献。这可以用 split 函数来实现:

const refs = input.split("\n");

然后我们需要遍历这个数组,给每一条参考文献条目生成正确的序号,这个任务可以分解为两步:

  1. 把条目中原有的序号去除

    序号的样式是 [<数字>],我们可以用正则表达式做匹配,然后把匹配到的字符串中序号的部分替换为空字符串,就可以去除原有的序号了。

    为了防止误伤条目里面的其他内容࿰

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值