惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

L
LangChain Blog
Martin Fowler
Martin Fowler
P
Palo Alto Networks Blog
MongoDB | Blog
MongoDB | Blog
A
About on SuperTechFans
Google DeepMind News
Google DeepMind News
博客园_首页
量子位
小众软件
小众软件
F
Full Disclosure
Vercel News
Vercel News
爱范儿
爱范儿
Engineering at Meta
Engineering at Meta
F
Fortinet All Blogs
博客园 - 聂微东
V
V2EX
Blog — PlanetScale
Blog — PlanetScale
罗磊的独立博客
WordPress大学
WordPress大学
D
Darknet – Hacking Tools, Hacker News & Cyber Security
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
T
Tor Project blog
Google DeepMind News
Google DeepMind News
M
MIT News - Artificial intelligence
L
Lohrmann on Cybersecurity
H
Hacker News: Front Page
Spread Privacy
Spread Privacy
AI
AI
C
Cyber Attacks, Cyber Crime and Cyber Security
C
CERT Recently Published Vulnerability Notes
D
Docker
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
Recorded Future
Recorded Future
L
LINUX DO - 热门话题
Microsoft Azure Blog
Microsoft Azure Blog
Recent Commits to openclaw:main
Recent Commits to openclaw:main
cs.AI updates on arXiv.org
cs.AI updates on arXiv.org
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
Latest news
Latest news
W
WeLiveSecurity
Application and Cybersecurity Blog
Application and Cybersecurity Blog
博客园 - 司徒正美
博客园 - 叶小钗
T
Threat Research - Cisco Blogs
P
Privacy International News Feed
O
OpenAI News
Help Net Security
Help Net Security
aimingoo的专栏
aimingoo的专栏
宝玉的分享
宝玉的分享
博客园 - Franky

少数派

派早报:Google 发布 Fitbit Air 等 - 少数派 「新人报到」確認需求,再開始 - 少数派 从 SOLO 独立开发者社区,我看到了越来越多开发者开始做自己的产品 - 少数派 我怎么管理那些"不常做,但总会忘"的生活事项 - 少数派 人形机器人量产元年,数据才是具身智能的“生死线” - 少数派 BuhoLaunchpad 高度还原 Mac 启动台:开发历程与思考 - 少数派 五年陪伴依然不舍,DIY 换壳后让罗技 MX Master 3 继续服役 - 少数派 新玩意 240|少数派的编辑们最近买了啥? - 少数派 一日一技|为什么你应该关闭 iOS 的键盘声音 - 少数派 我做了个插件和 Skills,一键提取任何网站的设计规范 Design.md - 少数派 住在三四线城市的你,该开始录播客了 - 少数派 甘南秘境,大白高国 - 少数派 AI的审美:谁让把我变成川内倫子 - 少数派 返工怎能不烦恼,打工人片单总有一部是你的「嘴替」 - 少数派 为了让「上厕所」更健康,我做了一个小工具 - 少数派 AI + Skill,能够让生成的文章去除 AI 味吗? - 少数派 新玩意|韶音OpenDots ONE 耳夹式耳机 - 少数派 《美满》| 在每一个春天的晚上相爱(362) - 少数派 新玩意|优篮子 PS01 MagSnap 磁吸支架 - 少数派 自我整合手记 | 我开始早睡了:用稳定规则,为自由托底 - 少数派 用龙虾(OpenClaw)两个多月,我最深的12个体会 - 少数派 听歌时间到,12 张你可能错过的 2025 华语乐坛好专辑 - 少数派 承诺能追吗 - 少数派 macOS 26启动台没了? 我做了个不一样的App启动器 - Keboard - 少数派 《四海为家的人》| INTJ对话INTJ(361) - 少数派 你发过的那些黑历史,是时候一次清干净了 - 少数派 新玩意:安安静静玩,越玩越专注:计客密码机 - 少数派 iPad 用户首次体验 Android 平板:vivo Pad6 Pro - 少数派 数据逻辑强 - 少数派 极北行+ | 一路向北,探访日本至北之地 | 001 - 少数派 万字剖析:千问App深度体验报告(2026) - 少数派 在2026年,如何真正防止别人抄袭你的作品 - 少数派 怎么用 50 块搭个 AI 语音助手?我踩了 3 天坑 - 少数派 YeeroAI:让 AI 对话真正成为知识管理的一部分 - 少数派 爬泰山 - 少数派 「旅图显影」 App 更新:这次,我们补上了一点「手感」 - 少数派 假期出门太折磨?我的 23 条经验帮你规划惬意旅行 - 少数派 工作流会变吗 - 少数派 Claude Opus 4.6 怎么用最省钱?我测了 5 种方案 - 少数派 GPT Image 2 让图文并茂不再稀罕 - 少数派 用户侧出发——什么是AI,我要不要学习? - 少数派 找片、转存、整理、播放一条龙!让你的付费网盘值回票价 - 少数派 欢迎试用!日课一问2.0插件 - 少数派 自己做的MDeditor,原本想购买 Typora 试了两次支付不成功,干脆自己做一个 - 少数派 vibe coding了一个 3MB 的小工具,让 ~/Downloads 彻底告别混乱 - 少数派 因为受不了 Mac 的风扇策略,我做了一个风扇控制工具 - 少数派 别只怪模型 - 少数派 Warp 终端的 AI 功能怎么用?我测了一周的体验 - 少数派 AI 写代码老是出 bug?这 5 个配置我后悔没早知道 - 少数派 「新玩意」苹果出相机可能就这样:Sigma BF + 45mm F2.8 DG Contemporary - 少数派 一个面向2030年的AI操作系统是什么样子的:浅谈cola这款有灵魂的Agent - 少数派 别只看写代码 - 少数派 每天解决10个问题,还是一口气攻坚解决400个? - 少数派 AI 交易机器人怎么搭?我用 Claude 跑了一周实盘 - 少数派 Maptoposter Online:把你爱的城市画成艺术海报 - 少数派 Function Calling 怎么用?我测了 3 个模型发现差距真大 - 少数派 Legend Talk:我做了个 AI 圆桌,让 160 位思想家围着你的问题转 - 少数派 如何找到自己的蓝方?在小县城寻找压力测试 - 少数派 语音输入与软件接口|2026年聊AI时,我们都聊些什么(上) - 少数派 混动已经卖爆,纯电又来补刀——钛7闪充版简直“不讲武德” - 少数派 本月玩什么|朋友收藏、识质存在、沙罗周期 - 少数派 为什么要每天坚持输出? - 少数派 Claude API 挂了好几个小时,你的项目有备用方案吗? - 少数派 Function Calling 没你想的复杂——我用它做了个有点用的工具 - 少数派 登录系统立即播放视频或者图片音乐的软件 - 少数派 我为什么创建 FlipHTML5 下载工具 - 少数派 残局没电?多品牌外设电量统一管理软件EasyBluetooth已支持RTSS游戏内显示以及AIDA64 - 少数派 前往通义路的路 - 少数派 太好看了,媲美Sun的个人导航页,NAS部署星云门户 - 少数派 乌黑嘴唇“一键检测”上线了 - 少数派 派早报:Claude AI 接入多个创意软件生态、FILCO 生产方接手品牌等 - 少数派 【更新】BearCLI、Claude 连接器与 MCP 服务器 - 少数派 记了上千条流水,还是看不懂财务?我做了一个让 AI 读懂账本的工作台 - 少数派 MINI R56 升级原厂 Sport 模式 - 少数派 新玩意 | 一棵柠檬树(仿真版) - 少数派 Momenta的“物理AI”野望,需迈过“含摩量”这道关 - 少数派 网页直接投屏控制手机!NAS一键部署PandaScrcpy,流畅丝滑可远程。 - 少数派 众测|邀你一同探索随身 AI 硬件入口 YoooClaw C·ONE - 少数派 2050大会:分享时间是真诚 参会记 - 少数派 iPad 赋能电影创作:国内首部宣纸手绘长片《燃比娃》的幕后故事 - 少数派 AI的审美:我用 8 个大模型给 100 张旅行照片打分 - 少数派 普通人如何破圈?去参加一个本地协会 - 少数派 把极空间的图标全换了,主题DIY全攻略打造你的专属NAS桌面 - 少数派 电子便签墙,帮你实现便签自由 - 少数派 我如何用三个 CLI 工具取代文档创建需求 - 少数派 原来真的有人可以玩一辈子 - 少数派 社区速递 139 | 派友热议三月买了啥、复古单反尼康 Df 体验 - 少数派 06 作品的赏析与评价 - 少数派 TDS REVIEW|索尼 WF-1000XM6 降噪真无线耳机体验 - 少数派 35.98万起售的第二代腾势D9,我看重的不是堆料,而是不凑合 - 少数派 鼠须管 Squirrel 皮肤配置指北 - 少数派 从watch ultra2换到redmi watch6 - 少数派 派早报:阿里巴巴发布视频生成模型 HappyHorse 1.0 等 - 少数派 别迷信1M - 少数派 家人们天塌了!网盘“大封杀”,多个渠道多条路,NAS部署PanHub - 少数派 AI与人勾心斗角!NAS一键部署AI狼人杀,假日休闲必备。 - 少数派 电商必备!Comfyui工作流批量生图插件,一次生成12张!支持Nano banana pro模型 - 少数派 Comfyui工作流配置Gpt-image-2模型教程,0.03/张 - 少数派 OpenClaw第三方APi怎么配置?可使用Gpt-image-2模型 - 少数派 会员社区话题精选 Ep. 103 - 少数派
帮人加中英文空格加到手软?用 textlint 自动完成文本检查与校对 - 少数派
2019-06-01 · via 少数派

很多人在学生时代应该都接触或使用过 Word 提供的 拼写检查工具,它可以帮助我们查找文本内容中常见的错别字语病。类似拼写检查工具我们也可以在其他平台和工具中看到,但功能也大多局限在前面提到的两个方面。

Word 拼写检查配置选项

在平时进行技术文档写作的过程中,我经常会通过自动化工具实现更进一步的拼写检查,甚至对格式进行自动化校对,例如自动检查中英文排版并添加空格、检查文章中的链接是否有效、检查一句话是否太长而不易于理解等等。能够满足这些需求的自动化检查校对工具不多,但 textlint 或许是最接近我期望的那一款。

textlint 这款开源工具由一位名叫 あず 的日本开发者制作,其灵感来源于代码自动格式化工具。textlint 使用 JavaScript 实现,我们可以通过编写一系列脚本来实现对文本内容和格式检查的各类个性化需求。

接下来,我就通过几个例子来演示 textlint 的安装和用法。

正式使用 textlint 之前我们需要先执行安装步骤。textlint 基于 JavaScript 语言来实现,其安装通过 npm 包管理工具来安装,你可以阅读 官方文档 提供的详细步骤。

具体到 macOS 上,我们只需要执行一行代码即可完成安装(在 Windows 上则需使用 PowerShell):

npm install textlint --global

前提是环境已安装了 Node.js 6.0.0+ 和 npm 2.0.0+ 依赖。

安装完成之后,重新打开终端或 PowerShell,键入 textlint 命令看是否能成功调用。如果出现了如下图所示的参数说明,则代表 textlint 已正确安装。

查看 textlint 是否安装成功

至此,我们已经完成了第一步,但要使用 textlint 提供的一系列功能,还需要安装相应的规则。你可以参考官方提供了一个 规则合集,其中涵盖了很多常用的文本内容检查场景。虽然目前大部分规则都仅支持日文和英文,支持中文的规则几乎没有,不过一部分日语规则还是可以在中文下正常使用。

textlint 用法实例

自动添加中英文空格

很多科技媒体会在写作时都会遵循一个排版规则,即在中英文之间保留一个空格。关于这项规则的详细说明,可以阅读 中文文案排版指北

保留一个空格从一定程度上提升了排版的美观度,虽然我已经养成了添加空格的习惯,但仍然有一定概率会漏掉。除此之外,帮别人检查格式问题时,空格也能让我们添加到手软。

除了此前很多人都在用的 pangu.js 这款工具,现在我们也可以借助 textlint 来解决这一需求。

自动添加空格的规则来源于 textlint-rule-ja-space-between-half-and-full-width,这个规则是针对日文开发,但中文同样可用。你需要使用命令安装此规则:

npm install textlint-rule-ja-space-between-half-and-full-width --global

值得注意的是,如果最开始安装 textlint 时使用了 --global 全局命令参数,后续安装规则时都需要添加此参数。接下来,我们尝试调用这条规则。

首先,通过终端切换到需要执行格式检查的目录下方,textlint 支持对多层级目录和多文件批量处理,所以一般切换至项目的根目录下方即可。

然后,执行 textlint --init 初始化 textlint 针对该目录的配置文件,执行后会自动生成一个名为 .textlintrc 的配置文件。该配置文件默认内容为空:

{
  "filters": {},
  "rules": {}
}

接下来,我们参考 textlint-rule-ja-space-between-half-and-full-width 文档中的说明,向配置文件中添加相应的规则:

{
    "filters": {},
    "rules": {
        "ja-space-between-half-and-full-width": {
            "space": "always"
        }
    }
}

此时,表明我们调用了已经安装的 ja-space-between-half-and-full-width 规则,执行时会自动在全角和半角字符之间添加一个空格,即可以达到中英文、中文和数字之间添加空格的效果。

接下来,只需要执行 textlint . 命令,即可实现对该目录及子目录下任意文本文件的格式检查。当然,你可以特别指定一个文件 textlint 示例文件.md 或者进行模糊匹配检查 textlint 示例*

针对示例文件进行检查

如上图所示,textlint 检查出了 示例文件.md 中有 4 个地方不符合 ja-space-between-half-and-full-width 规则要求的问题,即没有在中英文之间添加空格。

此时,textlint 并没有自动修复这些问题。如果你想要解决这些问题实现自动添加空格,执行 textlint --fix 示例文件.md 即可。

值得注意的是,默认情况下 textlint 只支持文本文件 .txt 和 Markdown 文件 .md 的自动检查和修复,其余后缀结尾的文件会被忽略。不过,对于像 HTML,RST 等常用的文件格式,你可以通过 安装插件 来支持。

例如,我平常会使用到一种由 Jupyter Notebook 生成的 .ipynb 文件格式。该文件格式虽然不属于前面提到的任意一种,但实际上其使用 JSON 进行编码保存。此时,我通过修改配置文件 .textlintrc,让 textlint 将 .ipynb 看作是 .md 文件进行处理,可以达到同样的效果。

{
    "filters": {},
    "rules": {
        "ja-space-between-half-and-full-width": {
            "space": "always"
        }
    },
    "plugins": {
        "@textlint/markdown": {
            "extensions": [".ipynb"]
        }
    }
}

也就是说,只要文件通过文本形式储存,无论其后缀如何,均可以使用 textlint 进行检查。

白名单和过滤

除了空格,写作时文本内容里可能还会出现对少儿不宜或者涉及政治的词语。因此对大众媒体的编辑而言,文本过滤是必不可少的一个流程。

我们可以借助于 textlint 配置文件中的 filter 实现黑名单和白名单效果。例如,可以将白名单词汇表 allow.json 文件添加到配置文件中。

{
    "filters": {
        "whitelist": {
            "whitelistConfigPaths": [
                "./allow.json"
            ]
        }
    }
}

自定义过滤还支持正则表达式,具体可以通过阅读 官方说明 了解。

更多通用规则

上面提到,由于 textlint 目前的大多数规则都是针对英文和日文开发,所以适用于中文的复杂规则尚且不多。这里,我根据自己平常的使用情况,再介绍几个对全语言通用的规则。

textlint-rule-max-number-of-lines 可以用于检查文档中的行数,如果超出了规定的行数即会进行提示。该规则适合于规定字数或者行数的文本内容检查。textlint-rule-max-comma 可以用于检查一个长句子中限制的短句数量,也就是包含逗号的数量。如果一个句子包含逗号超过设定,也会进行提示。

技术文档写作时,一般要求对 ?和 !之类的标点符号进行严格限制。textlint-rule-no-exclamation-question-mark 即可强制修正问号和感叹号的使用。

如果文档中会引用较多的参考链接,textlint-rule-no-dead-link 这条规则可以帮助检查外部链接是否有效。我非常喜欢这条规则,并且会定期使用其检查文章中外部链接的可用性。

对于这些规则的使用,你只需要参考其文档安装好之后,将其补充到配置文件 .textlintrc 中即可。textlint 的优势之一就在于此,你可以针对一个写作项目同时执行多条文本规则检查。

小结

在我的日常写作中,已经体会到了 textlint 文本自动化检查校对带来的方便,正因为此才推荐给大家。我认为每一位高频写作者和编辑都可以尝试使用 textlint,这款工具能够有效改善内容的质量。

遗憾之处在于,目前针对中文的规则还是太少。如果你去查看针对日文的规则列表,你会发现很多规则看起来就非常高效。接下来,我也会投入到制作针对中文技术文档写作的规则中去,争取能够帮助自己和更多的作者。

> 下载少数派 客户端、关注 少数派公众号 ,了解更多有趣的应用 🚀

> 特惠、好用的硬件产品,尽在 少数派 Pi Store 商店 🛒