网站首页 > 基础教程 正文
Mac/iOS自带输入法导入第三方输入法词库
苹果的自带输入法简洁美观流畅,对各种软件的兼容性也是最好的,但是很明显的不足的就是词库没有第三方输入法强大。下面就介绍如何把第三方输入法个人词库导入到苹果自带输入法,原理都类似,支持百度输入法、搜狗输入法
词库文件
macOS、iOS上面输入法里面都有文本替换,这就可以让用户自定义词库,但是并没有导入的选项。但是发现在Mac上面选中文本项之后往桌面拖动是会在桌面生成一个 用户词典.plist 的文件,所以我们可以大胆把已有的文本替换都删除,把生成的plist文件拖进窗口里面,发现都还原了,我们可以推断这就是苹果自带输入法的自定义的词库文件了。
打开 用户词典.plist 的文件,发现里面的结构也比较简单清晰,词库文件规则也一目了然,如下图:
导入百度输入法用户词库
在百度输入法用户偏好设置里面选择导出用户词库文件,使用编辑器打开文件,发现并没有加密,打开文件,内容格式如下:
接下来我们就可以写一个脚本来对百度输入法导出的词库文件内容格式进行转换,转换逻辑都类似,不同的语言都可以实现,因为我是Web前端开发,所以用NodeJS来对文件进行处理。
用NodeJS转换词库文件
需要注意的是,你在VSCode打开百度输入法词库文件,发现其编码是UTF-16 LE,我在用NodeJS读取文件需要使用encoding UCS-2,否则会出现乱码。下面写了一个通用的脚本word2plist.js
const { join } = require('path');
const { readFileSync, writeFileSync } = require('fs');
const fileName = process.argv.pop();
const wordStr = readFileSync(join(__dirname, fileName), { encoding: 'ucs-2'}).toString();
const wordList = wordStr.split(/\r\n/);
const plist = wordList.filter(v => v).map(record => {
const match = record.match(/(.+)\((.+)\)/);
const phrase = match[1];
const shortcut = match[2].replace(/\|/g, '');
return `<dict>
<key>phrase</key>
<string>${phrase}</string>
<key>shortcut</key>
<string>${shortcut}</string>
</dict>`;
}).join('\r\n');
writeFileSync(join(__dirname, `${fileName}.plist`), `<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<array>
${plist}
</array>
</plist>`);
安装NodeJS 之后,就可以直接运行:node word2plist.js 文件路径,比如导出的文件名是baidu,我们就可以运行
node word2plist.js baidu
运行之后就会在目录下生成一个baidu.plist文件,我们拖动文件到文本替换窗口里面,发现词库全部导入进去了!
导入百度输入法词库文件
导入搜狗输入法词库
因为搜狗输入法mac版本升级之后导出的词库bin文件是加密的,我们可以使用深蓝词库转换成百度的,然后用上面的脚本同样适用,QQ拼音等其他输入法用同意做法也是可以的。
PS:词库是可以自动同步到iPhone设备上的,所以打开手机上的文本替换发现刚才导入的词库全有了!因为我的词库量太大了,不得不吐槽一下,手机上打开文本替换动不动就会卡死,苹果官方目前对该长列表展示的优化不足呀…
猜你喜欢
- 2024-12-22 一大波开源小抄来袭 开源小说软件下载
- 2024-12-22 「Electron跨平台桌面应用开发 4」系统托盘功能
- 2024-12-22 超级简单 Bing美图每天自动收 收藏美图
- 2024-12-22 使用Python进行并发编程 python 并发编程
- 2024-12-22 我的世界计分板命令创建队伍教程详解
- 2024-12-22 Webpack5 配置手册(从0开始) webpack简单配置
- 2024-12-22 electron开发桌面应用实现串口通信,看完你就学会了
- 2024-12-22 JavaScript中原生的原型 Prototype
- 2024-12-22 webpack系列学习-基本用法 webpack基本使用
- 2024-12-22 前端技术探秘-Nodejs的CommonJS规范实现原理
- 最近发表
- 标签列表
-
- gitpush (61)
- pythonif (68)
- location.href (57)
- tail-f (57)
- pythonifelse (59)
- deletesql (62)
- c++模板 (62)
- css3动画 (57)
- c#event (59)
- linuxgzip (68)
- 字符串连接 (73)
- nginx配置文件详解 (61)
- html标签 (69)
- c++初始化列表 (64)
- exec命令 (59)
- canvasfilltext (58)
- mysqlinnodbmyisam区别 (63)
- arraylistadd (66)
- node教程 (59)
- console.table (62)
- c++time_t (58)
- phpcookie (58)
- mysqldatesub函数 (63)
- window10java环境变量设置 (66)
- c++虚函数和纯虚函数的区别 (66)